mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 06:57:58 +00:00
Add test for cli keystore path generation (#4571)
* Add test for cli keystore path generation * Fix test
This commit is contained in:
@@ -351,7 +351,10 @@ impl<'a> ParseAndPrepareBuildSpec<'a> {
|
||||
|
||||
if spec.boot_nodes().is_empty() && !self.params.disable_default_bootnode {
|
||||
let base_path = base_path(&self.params.shared_params, self.version);
|
||||
let cfg = sc_service::Configuration::<C,_,_>::default_with_spec_and_base_path(spec.clone(), Some(base_path));
|
||||
let cfg = sc_service::Configuration::<C,_,_>::default_with_spec_and_base_path(
|
||||
spec.clone(),
|
||||
Some(base_path),
|
||||
);
|
||||
let node_key = node_key_config(
|
||||
self.params.node_key_params,
|
||||
&Some(cfg.in_chain_config_dir(DEFAULT_NETWORK_CONFIG_PATH).expect("We provided a base_path"))
|
||||
@@ -750,26 +753,33 @@ fn input_keystore_password() -> Result<String, String> {
|
||||
}
|
||||
|
||||
/// Fill the password field of the given config instance.
|
||||
fn fill_config_keystore_password<C, G, E>(
|
||||
fn fill_config_keystore_password_and_path<C, G, E>(
|
||||
config: &mut sc_service::Configuration<C, G, E>,
|
||||
cli: &RunCmd,
|
||||
) -> Result<(), String> {
|
||||
if let KeystoreConfig::Path { password, .. } = &mut config.keystore {
|
||||
*password = if cli.password_interactive {
|
||||
#[cfg(not(target_os = "unknown"))]
|
||||
{
|
||||
Some(input_keystore_password()?.into())
|
||||
}
|
||||
#[cfg(target_os = "unknown")]
|
||||
None
|
||||
} else if let Some(ref file) = cli.password_filename {
|
||||
Some(fs::read_to_string(file).map_err(|e| format!("{}", e))?.into())
|
||||
} else if let Some(ref password) = cli.password {
|
||||
Some(password.clone().into())
|
||||
} else {
|
||||
None
|
||||
};
|
||||
}
|
||||
let password = if cli.password_interactive {
|
||||
#[cfg(not(target_os = "unknown"))]
|
||||
{
|
||||
Some(input_keystore_password()?.into())
|
||||
}
|
||||
#[cfg(target_os = "unknown")]
|
||||
None
|
||||
} else if let Some(ref file) = cli.password_filename {
|
||||
Some(fs::read_to_string(file).map_err(|e| format!("{}", e))?.into())
|
||||
} else if let Some(ref password) = cli.password {
|
||||
Some(password.clone().into())
|
||||
} else {
|
||||
None
|
||||
};
|
||||
|
||||
let path = cli.keystore_path.clone().or(
|
||||
config.in_chain_config_dir(DEFAULT_KEYSTORE_CONFIG_PATH)
|
||||
);
|
||||
|
||||
config.keystore = KeystoreConfig::Path {
|
||||
path: path.ok_or_else(|| "No `base_path` provided to create keystore path!")?,
|
||||
password,
|
||||
};
|
||||
|
||||
Ok(())
|
||||
}
|
||||
@@ -840,7 +850,7 @@ where
|
||||
{
|
||||
let mut config = create_config_with_db_path(spec_factory, &cli.shared_params, &version)?;
|
||||
|
||||
fill_config_keystore_password(&mut config, &cli)?;
|
||||
fill_config_keystore_password_and_path(&mut config, &cli)?;
|
||||
|
||||
let is_dev = cli.shared_params.dev;
|
||||
let is_authority = cli.validator || cli.sentry || is_dev || cli.keyring.account.is_some();
|
||||
@@ -875,12 +885,6 @@ where
|
||||
)?
|
||||
}
|
||||
|
||||
let default_keystore_path = config.in_chain_config_dir(DEFAULT_KEYSTORE_CONFIG_PATH);
|
||||
|
||||
if let KeystoreConfig::Path { path, ..} = &mut config.keystore {
|
||||
*path = cli.keystore_path.or(default_keystore_path);
|
||||
}
|
||||
|
||||
// set sentry mode (i.e. act as an authority but **never** actively participate)
|
||||
config.sentry_mode = cli.sentry;
|
||||
|
||||
@@ -1205,4 +1209,48 @@ mod tests {
|
||||
assert!(no_config_dir().is_ok());
|
||||
assert!(some_config_dir("x".to_string()).is_ok());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn keystore_path_is_generated_correctly() {
|
||||
let chain_spec = ChainSpec::from_genesis(
|
||||
"test",
|
||||
"test-id",
|
||||
|| (),
|
||||
Vec::new(),
|
||||
None,
|
||||
None,
|
||||
None,
|
||||
None,
|
||||
);
|
||||
|
||||
let version_info = VersionInfo {
|
||||
name: "test",
|
||||
version: "42",
|
||||
commit: "234234",
|
||||
executable_name: "test",
|
||||
description: "cool test",
|
||||
author: "universe",
|
||||
support_url: "com",
|
||||
};
|
||||
|
||||
for keystore_path in vec![None, Some("/keystore/path")] {
|
||||
let mut run_cmds = RunCmd::from_args();
|
||||
run_cmds.shared_params.base_path = Some(PathBuf::from("/test/path"));
|
||||
run_cmds.keystore_path = keystore_path.clone().map(PathBuf::from);
|
||||
|
||||
let node_config = create_run_node_config::<(), _, _, _>(
|
||||
run_cmds.clone(),
|
||||
|_| Ok(Some(chain_spec.clone())),
|
||||
"test",
|
||||
&version_info,
|
||||
).unwrap();
|
||||
|
||||
let expected_path = match keystore_path {
|
||||
Some(path) => PathBuf::from(path),
|
||||
None => PathBuf::from("/test/path/chains/test-id/keystore"),
|
||||
};
|
||||
|
||||
assert_eq!(expected_path, node_config.keystore.path().unwrap().to_owned());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user