Skip to content

Commit

Permalink
[feature] #3974: Add subcommand into iroha_client_cli to transfer dom…
Browse files Browse the repository at this point in the history
…ains

Signed-off-by: Vladimir Pesterev <[email protected]>
  • Loading branch information
pesterev committed Nov 7, 2023
1 parent c3adf25 commit 153c4c6
Show file tree
Hide file tree
Showing 3 changed files with 44 additions and 7 deletions.
13 changes: 9 additions & 4 deletions client_cli/pytests/src/client_cli/client_cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -246,18 +246,23 @@ def should(self, _expected):
"""
return self

def execute(self):
def execute(self, command=None):
"""
Executes the command and captures stdout and stderr.
:return: The current ClientCli object.
:rtype: ClientCli
"""
command = '\n'.join(self.command)
with allure.step(f'{command} on the {str(self.config.torii_api_port)} peer'):
if command is None:
command = self.command
else:
command = [self.BASE_PATH] + self.BASE_FLAGS + command.split()
allure_command = ' '.join(map(str, command[3:]))
print(allure_command)
with allure.step(f'{allure_command} on the {str(self.config.torii_api_port)} peer'):
try:
with subprocess.Popen(
self.command,
command,
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
text=True
Expand Down
2 changes: 1 addition & 1 deletion client_cli/pytests/test/domains/test_register_domains.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ def test_register_domain(
GIVEN_fake_name):
with allure.step(
f'WHEN client_cli registers the domain name "{GIVEN_fake_name}"'):
client_cli.register().domain(GIVEN_fake_name)
client_cli.execute(f'domain register --id={GIVEN_fake_name}')
with allure.step(
f'THEN Iroha should have the domain name "{GIVEN_fake_name}"'):
iroha.should(have.domain(GIVEN_fake_name))
Expand Down
36 changes: 34 additions & 2 deletions client_cli/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -363,11 +363,13 @@ mod domain {
/// List domains
#[clap(subcommand)]
List(List),
/// Transfer domain
Transfer(Transfer),
}

impl RunArgs for Args {
fn run(self, context: &mut dyn RunContext) -> Result<()> {
match_all!((self, context), { Args::Register, Args::List })
match_all!((self, context), { Args::Register, Args::List, Args::Transfer })
}
}

Expand Down Expand Up @@ -420,6 +422,36 @@ mod domain {
Ok(())
}
}

/// Transfer a domain between accounts
#[derive(Debug, StructOpt)]
pub struct Transfer {
/// Domain name as double-quited string
#[structopt(short, long)]
pub id: DomainId,
/// Account from which to transfer (in form `name@domain_name')
#[structopt(short, long)]
pub from: AccountId,
/// Account to which to transfer (in form `name@domain_name')
#[structopt(short, long)]
pub to: AccountId,
/// The JSON/JSON5 file with key-value metadata pairs
#[structopt(short, long, default_value = "")]
pub metadata: super::Metadata,
}

impl RunArgs for Transfer {
fn run(self, context: &mut dyn RunContext) -> Result<()> {
let Self {
id,
from,
to,
metadata: Metadata(metadata),
} = self;
let transfer_domain = TransferExpr::new(from, id, to);
submit([transfer_domain], metadata, context).wrap_err("Failed to transfer domain")
}
}
}

mod account {
Expand Down Expand Up @@ -774,7 +806,7 @@ mod asset {
/// Account from which to transfer (in form `name@domain_name')
#[structopt(short, long)]
pub from: AccountId,
/// Account from which to transfer (in form `name@domain_name')
/// Account to which to transfer (in form `name@domain_name')
#[structopt(short, long)]
pub to: AccountId,
/// Asset id to transfer (in form like `name#domain_name')
Expand Down

0 comments on commit 153c4c6

Please sign in to comment.