-
Notifications
You must be signed in to change notification settings - Fork 212
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
feat: allow using sharded repodata #2467
feat: allow using sharded repodata #2467
Conversation
The documentation can go here: https://pixi.sh/latest/reference/pixi_configuration/ |
When I enable all logic I get an error on the normal conda-forge. I think rattler should just skip this and try the next option. [repodata-config]
disable-jlap = false
disable-bzip2 = false
disable-zstd = false
disable-sharded = false
|
Yes correct you have to configure it on a per channel basis currently. |
I would like to add this test, but currently the #[test]
fn test_repodata_config() {
let toml = r#"
[repodata-config]
disable-jlap = true
disable-bzip2 = true
disable-zstd = true
disable-sharded = true
[repodata-config."https://prefix.dev/conda-forge"]
disable-jlap = false
disable-bzip2 = false
disable-zstd = false
disable-sharded = false
[repodata-config."https://conda.anaconda.org/conda-forge"]
disable-jlap = false
disable-bzip2 = false
disable-zstd = false
"#;
let (config, _) = Config::from_toml(toml).unwrap();
let repodata_config = config.repodata_config();
assert_eq!(repodata_config.default.disable_jlap, Some(true));
assert_eq!(repodata_config.default.disable_bzip2, Some(true));
assert_eq!(repodata_config.default.disable_zstd, Some(true));
assert_eq!(repodata_config.default.disable_sharded, Some(true));
let per_channel = repodata_config.clone().per_channel;
assert_eq!(per_channel.len(), 2);
let prefix_config = per_channel.get(&Url::from_str("https://prefix.dev/conda-forge").unwrap()).unwrap();
assert_eq!(prefix_config.disable_jlap, Some(false));
assert_eq!(prefix_config.disable_bzip2, Some(false));
assert_eq!(prefix_config.disable_zstd, Some(false));
assert_eq!(prefix_config.disable_sharded, Some(false));
let anaconda_config = per_channel.get(&Url::from_str("https://conda.anaconda.org/conda-forge").unwrap()).unwrap();
assert_eq!(anaconda_config.disable_jlap, Some(false));
assert_eq!(anaconda_config.disable_bzip2, Some(false));
assert_eq!(anaconda_config.disable_zstd, Some(false));
// TODO: disable-sharded is not set so default should be used
// assert_eq!(anaconda_config.disable_sharded, Some(true));
} So a user can't do this right now and expect [repodata-config."https://prefix.dev/conda-forge"]
disable-sharded = true
[repodata-config]
disable-jlap = true
disable-bzip2 = false
disable-zstd = true
disable-sharded = false |
Can't rattler just ignore this error? It's not helpful for the user and they also shouldn't care about how the repodata is fetched, as long as the fastest version is used when possible. |
…ive a useful warning which it doesn't yet.
I like the added config flexibility. I think I would really like it if we also support setting things based on the "prefix" of the URL, so that you can configure it for a wider set of channels. E.g. adding the option to set
for all channels on prefix.dev – this is also how the mirror config works :) |
@ruben-arts @wolfv all your concerns should be addressed now. Could you take another look? |
Btw @ruben-arts I changed your code. Instead of merging after deserialization its merged when passing to rattler. I think the datastructure in the config should be kept as close to the source as possible. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
SPEEED
Enables sharded repodata for specific channels.
Add:
To your global config to not disable sharded repodata for all prefix channels. The double negation is there because in the future we might want to enable sharded repodata by default.
This PR is in draft because conda/rattler#910 needs to be merged first.
@ruben-arts is there a good place to add this to the documentation?