Skip to content

Commit

Permalink
cli: Fix custom provider.cluster (coral-xyz#3428)
Browse files Browse the repository at this point in the history
  • Loading branch information
acheroncrypto authored Dec 14, 2024
1 parent 2ae3774 commit 135d7e0
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 7 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,7 @@ The minor version will be incremented upon a breaking change and the patch versi
- cli: Avoid extra IDL generation during `verify` ([#3398](https://github.com/coral-xyz/anchor/pull/3398)).
- lang: Require `zero` accounts to be unique ([#3409](https://github.com/coral-xyz/anchor/pull/3409)).
- lang: Deduplicate `zero` accounts against `init` accounts ([#3422](https://github.com/coral-xyz/anchor/pull/3422)).
- cli: Fix custom `provider.cluster` ([#3428](https://github.com/coral-xyz/anchor/pull/3428)).

### Breaking

Expand Down
52 changes: 45 additions & 7 deletions cli/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,8 @@ use dirs::home_dir;
use heck::ToSnakeCase;
use reqwest::Url;
use serde::de::{self, MapAccess, Visitor};
use serde::{Deserialize, Deserializer, Serialize};
use serde::ser::SerializeMap;
use serde::{Deserialize, Deserializer, Serialize, Serializer};
use solana_cli_config::{Config as SolanaConfig, CONFIG_FILE};
use solana_sdk::clock::Slot;
use solana_sdk::pubkey::Pubkey;
Expand Down Expand Up @@ -590,11 +591,29 @@ struct _Config {

#[derive(Debug, Serialize, Deserialize)]
struct Provider {
#[serde(deserialize_with = "des_cluster")]
#[serde(serialize_with = "ser_cluster", deserialize_with = "des_cluster")]
cluster: Cluster,
wallet: String,
}

fn ser_cluster<S: Serializer>(cluster: &Cluster, s: S) -> Result<S::Ok, S::Error> {
match cluster {
Cluster::Custom(http, ws) => {
match (Url::parse(http), Url::parse(ws)) {
// If `ws` was derived from `http`, serialize `http` as string
(Ok(h), Ok(w)) if h.domain() == w.domain() => s.serialize_str(http),
_ => {
let mut map = s.serialize_map(Some(2))?;
map.serialize_entry("http", http)?;
map.serialize_entry("ws", ws)?;
map.end()
}
}
}
_ => s.serialize_str(&cluster.to_string()),
}
}

fn des_cluster<'de, D>(deserializer: D) -> Result<Cluster, D::Error>
where
D: Deserializer<'de>,
Expand Down Expand Up @@ -1465,15 +1484,34 @@ mod tests {
wallet = \"id.json\"
";

const CUSTOM_CONFIG: &str = "
#[test]
fn parse_custom_cluster_str() {
let config = Config::from_str(
"
[provider]
cluster = { http = \"http://my-url.com\", ws = \"ws://my-url.com\" }
cluster = \"http://my-url.com\"
wallet = \"id.json\"
";
",
)
.unwrap();
assert!(!config.features.skip_lint);

// Make sure the layout of `provider.cluster` stays the same after serialization
assert!(config
.to_string()
.contains(r#"cluster = "http://my-url.com""#));
}

#[test]
fn parse_custom_cluster() {
let config = Config::from_str(CUSTOM_CONFIG).unwrap();
fn parse_custom_cluster_map() {
let config = Config::from_str(
"
[provider]
cluster = { http = \"http://my-url.com\", ws = \"ws://my-url.com\" }
wallet = \"id.json\"
",
)
.unwrap();
assert!(!config.features.skip_lint);
}

Expand Down

0 comments on commit 135d7e0

Please sign in to comment.