-
Notifications
You must be signed in to change notification settings - Fork 189
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
fix(sozo): model get not using prefixes #2867
base: main
Are you sure you want to change the base?
Changes from 1 commit
69d83d0
f34a85e
2df1d0e
fee9cfb
2b0dac4
183ae33
efe1905
7d3d719
018847f
47df4b2
cfa44f4
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,6 @@ | ||
use anyhow::Result; | ||
use clap::{Args, Subcommand}; | ||
use dojo_world::config::calldata_decoder; | ||
use scarb::core::Config; | ||
use sozo_ops::model; | ||
use sozo_ops::resource_descriptor::ResourceDescriptor; | ||
|
@@ -109,8 +110,11 @@ hashes, called 'hash' in the following documentation. | |
|
||
#[arg(value_name = "KEYS")] | ||
#[arg(value_delimiter = ',')] | ||
#[arg(help = "Comma seperated values e.g., 0x12345,0x69420,...")] | ||
keys: Vec<Felt>, | ||
#[arg(help = "Comma separated values e.g., \ | ||
0x12345,0x69420,sstr:\"hello\",sstr:\"misty\". Supported prefixes:\n \ | ||
- sstr: A cairo short string\n \ | ||
- no prefix: A cairo felt")] | ||
keys: String, | ||
|
||
#[command(flatten)] | ||
world: WorldOptions, | ||
|
@@ -119,7 +123,9 @@ hashes, called 'hash' in the following documentation. | |
starknet: StarknetOptions, | ||
|
||
#[arg(short, long)] | ||
#[arg(help = "Block number at which to retrieve the model data (pending block by default)")] | ||
#[arg( | ||
help = "Block number at which to retrieve the model data (pending block by default)" | ||
)] | ||
block: Option<u64>, | ||
}, | ||
} | ||
|
@@ -205,6 +211,8 @@ impl ModelArgs { | |
let (world_diff, provider, _) = | ||
utils::get_world_diff_and_provider(starknet, world, &ws).await?; | ||
|
||
let keys = calldata_decoder::decode_calldata(&keys)?; | ||
|
||
let (record, _, _) = model::model_get( | ||
tag.to_string(), | ||
keys, | ||
|
@@ -222,3 +230,35 @@ impl ModelArgs { | |
}) | ||
} | ||
} | ||
|
||
#[cfg(test)] | ||
mod tests { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Thank you for thinking about tests. In the current context, this test should already be covered into the You could write a test on the argument though. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Awesome, that'll be the better option. These tests were meant to go away eventually. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. That's actually good having those here for the command, thank you! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. My pleasure, sir. |
||
use super::*; | ||
use starknet::core::utils::cairo_short_string_to_felt; | ||
|
||
#[test] | ||
fn test_short_string_equals_felt() { | ||
// Test that sstr:"misty" equals 0x6d69737479 | ||
let with_prefix = "sstr:\"misty\""; | ||
let with_hex = "0x6d69737479"; | ||
|
||
let felt_from_string = calldata_decoder::decode_calldata(with_prefix).unwrap(); | ||
let felt_from_hex = calldata_decoder::decode_calldata(with_hex).unwrap(); | ||
|
||
assert_eq!(felt_from_string, felt_from_hex); | ||
assert_eq!(felt_from_string[0], Felt::from_hex_str("0x6d69737479").unwrap()); | ||
} | ||
|
||
#[test] | ||
fn test_hex_equals_decimal() { | ||
// Test that 0x6d69737479 equals 469920609401 | ||
let with_hex = "0x6d69737479"; | ||
let with_decimal = "469920609401"; | ||
|
||
let felt_from_hex = calldata_decoder::decode_calldata(with_hex).unwrap(); | ||
let felt_from_decimal = calldata_decoder::decode_calldata(with_decimal).unwrap(); | ||
|
||
assert_eq!(felt_from_hex, felt_from_decimal); | ||
assert_eq!(felt_from_hex[0], Felt::from(469920609401u128)); | ||
} | ||
} |
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.
In the case of the keys, only
one felt long
serialized type are supported (everything that can fit in one felt).That's great you've only put the
sstr
which is the only one supported actually.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.
We may add a check that only this prefix is actually used, wdyt?
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.
Yeah, the check will be quite useful. I'll add it.