Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

show latest major version available in gleam deps update #3876

Open
wants to merge 18 commits into
base: main
Choose a base branch
from

Conversation

andho
Copy link

@andho andho commented Nov 22, 2024

This PR aims to solve #3843.
The sample output from that issue:

 % gleam deps update
  Resolving versions
Downloading packages
 Downloaded 2 packages in 0.01s
 
Hint: the following dependencies have new major versions available...

- wibble@2
- wobble@3

Todos

  • Handle Async: fireoff the checks and show the results at the end. Didn't make sense to do this.
  • Telemetry? Not sure it's needed for this optional part.
  • Merge version check into a single call Hexpm API doesn't have this. Went with cache instead.
  • Get the direct dependencies only

@lpil
Copy link
Member

lpil commented Dec 2, 2024

Hello! Are you still working on this one? Thanks

@andho
Copy link
Author

andho commented Dec 5, 2024

Hello! Are you still working on this one? Thanks

I was hoping to work on it this weekend but some things have come up. I can only get back to it next weekend.

@andho andho force-pushed the notify-major-version branch from 320e39f to fa633dc Compare December 6, 2024 03:33
@andho andho marked this pull request as ready for review December 6, 2024 15:25
@andho
Copy link
Author

andho commented Dec 6, 2024

Just the major version hist without any other output is weird though:
image

Helpful, but looks weird.

@andho andho force-pushed the notify-major-version branch from 300e9eb to 2f1055d Compare December 9, 2024 11:02
@inoas
Copy link
Contributor

inoas commented Dec 9, 2024

Could a flag be provided that forces a non-zero exit-code if major deps updates are available?

Would that make sense?

The idea would be to have a CI check that goes red if deps are not up to date.

Copy link
Member

@lpil lpil left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Very nice! I've left some small notes inline.

]
.into_iter()
.collect(),
//requirements: HashMap::new(),
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unused code here

Copy link
Author

@andho andho Dec 12, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Haha, this is embarrassing.
PS. Fixed.

compiler-cli/src/dependencies.rs Show resolved Hide resolved
let Some(latest) = &hexpackage
.releases
.iter()
.map(|release| release.version.clone())
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can take a reference here and avoid cloning

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed

Comment on lines 88 to 89
.sorted_by(|a, b| b.cmp(a))
.next()
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Using .max will be faster than sorting and taking the first

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed.


// lazily assuming the longest version could be 8 characters. eg: 1.1234.2
// excluding qualifiers other than x.y.z
eprintln!("{name}:{padding} {v1:<8} -> {v2:<8}");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's render this to a string and then snapshot test the function. This function can then just print the string and not be responsible for formatting and printing

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done.

@lpil lpil marked this pull request as draft December 9, 2024 15:55
@andho andho force-pushed the notify-major-version branch from 0781fc3 to c2e7c65 Compare December 12, 2024 16:21
@andho
Copy link
Author

andho commented Dec 13, 2024

Could a flag be provided that forces a non-zero exit-code if major deps updates are available?

Would that make sense?

The idea would be to have a CI check that goes red if deps are not up to date.

@inoas I think the flag would make more sense in a gleam deps outdated command instead.

@andho andho force-pushed the notify-major-version branch 2 times, most recently from 100bf86 to 839318a Compare December 13, 2024 12:54
@andho andho marked this pull request as ready for review December 13, 2024 13:03
@andho andho changed the title Draft: show latest major version available in gleam deps update show latest major version available in gleam deps update Dec 14, 2024
@andho andho requested a review from lpil December 14, 2024 13:05
Copy link
Member

@lpil lpil left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great, thank you.

image

I gave it a try and while the information is there and useful I don't think it fits in at all with any of the other information printed. How can we show this better?

Should it be shown for all resolution or only for gleam update? If the latter it would be easier to make a good output format for it.

@andho
Copy link
Author

andho commented Dec 18, 2024

Should it be shown for all resolution or only for gleam update?

It makes sense to show for gleam update and gleam deps download

Although it was helpful when I recently did gleam build and I saw that decode package was updated to 1.0.0. But due to the execution order it would take some rearranging to get this output to come last.

I'd say for an MVP show only in gleam update and gleam deps download. I'll only have to add a flag to download fn.

@lpil
Copy link
Member

lpil commented Dec 19, 2024

Sounds great!

…cy resolution and major version resolution to reduce network calls to hexpm ♻️
Changed PackageFetcher to use impl or a generic.
This will avoid dynamic dispatch and there is only one implementation
for production so monomorphization will not increase the bin size.
… struct impl ♻️

The struct now holds the relevant dependencies that were being passed
around with each function call.
Although Rc is used, it is still cloned in
dependency::DependencyProvider as it needs to sort the releases
@andho andho force-pushed the notify-major-version branch from ad3d34d to 22b1135 Compare December 28, 2024 06:45
@andho andho requested a review from lpil December 28, 2024 06:47
Copy link
Member

@lpil lpil left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks great!! Thank you. I've left a few tiny notes inline.

@@ -219,73 +221,75 @@ pub fn download<Telem: Telemetry>(
// manifest which will result in the latest versions of the dependency
// packages being resolved (not the locked ones).
use_manifest: UseManifest,
// If true we check for major version updates and print them to the console.
check_major_versions: bool,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Create an enum instead of using bools please. true and false mean nothing without context so they are hard to understand. See the other arguments for examples.

tracing::debug!("writing_manifest_toml");
write_manifest_to_disc(paths, &manifest)?;
output_string
.push_str("\nHint: the following dependencies have new major versions available:\n\n");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
.push_str("\nHint: the following dependencies have new major versions available:\n\n");
.push_str("\nThe following dependencies have new major versions available:\n\n");

/**
* Used to compare 2 versions of a package.
*/
pub type PackageVersionDiffs = HashMap<String, (Version, Version)>;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's either use this always or remove it

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's either use this always or remove it

I'm not sure what you mean. PackageVersionDiffs are used only for the major versions check currently. I don't see any other place making comparisons between 2 versions (except probably within pubgrub which makes comparisons betweens many versions probably).

Is you suggestion to remove the type and use HashMap<String, (Version, Version)> everywhere?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Either always use it or always using the underlying type is fine. We don't want a mix.

fn should_use_manifest(mut self) -> Self {
self.use_manifest = UseManifest::Yes;
self
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is cool!

Another option which can be convenient at times is to have a struct with public fields and have an into_dependency_manager() method or something like that

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I looked into builder pattern and init pattern (misnamed but similar to what you're suggesting). But as the tokio runtime, Package Fetcher and Telemetry needs to be specified, I cannot implement Default. Which means I'll have to define all struct fields at callsite. Which means any addition or change to the struct will require changes at all callsites.

Alternatively I could go for a builder, but seems too small right now.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Although...I could make it DependencyManagerConfig.into_dependecy_manager(runtime: ..., package_fetcher: ..., telemetry: ...).

@lpil
Copy link
Member

lpil commented Jan 9, 2025

Are you still planning to work on this? Thank you 🙏

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants