From 4e56a2e55a211e0de2fe858fabe59a09a9e355e2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?dj8yf0=CE=BCl?= <26653921+dj8yfo@users.noreply.github.com> Date: Sun, 19 Nov 2023 16:35:11 +0200 Subject: [PATCH] chore: update `near-sdk`, `near-abi`, `borsh` version (#109) --- Cargo.lock | 64 ++- cargo-near/Cargo.toml | 2 +- integration-tests/Cargo.toml | 4 +- integration-tests/src/lib.rs | 23 +- integration-tests/templates/_Cargo.toml | 4 +- .../negative/_Cargo_no_abi_feature.toml | 4 +- .../sdk-dependency/_Cargo_explicit.toml | 4 +- .../_Cargo_local_path_with_version.toml | 2 +- .../_Cargo_multiple_features.toml | 4 +- .../_Cargo_no_default_features.toml | 4 +- .../_Cargo_platform_specific.toml | 8 +- integration-tests/tests/abi/borsh_schema.rs | 432 ++++++++++-------- integration-tests/tests/abi/json_schema.rs | 9 +- integration-tests/tests/cargo/mod.rs | 4 + 14 files changed, 353 insertions(+), 215 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 9dd472f1..8bbf3cf9 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -606,6 +606,16 @@ dependencies = [ "hashbrown 0.13.2", ] +[[package]] +name = "borsh" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "acedd71cd81a2231f8c032b8330184e4e290374ca4e782aa95916b17e04b71b8" +dependencies = [ + "borsh-derive 1.1.0", + "cfg_aliases", +] + [[package]] name = "borsh-derive" version = "0.9.3" @@ -632,6 +642,20 @@ dependencies = [ "syn 1.0.109", ] +[[package]] +name = "borsh-derive" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e1dc1d79a037b13a874b34529d69de112c654da33311fcb68fedcf70a65a3914" +dependencies = [ + "once_cell", + "proc-macro-crate 1.3.1", + "proc-macro2", + "quote", + "syn 2.0.38", + "syn_derive", +] + [[package]] name = "borsh-derive-internal" version = "0.9.3" @@ -789,7 +813,7 @@ dependencies = [ "env_logger", "libloading", "log", - "near-abi", + "near-abi 0.3.0", "rustc_version", "schemars", "serde_json", @@ -819,7 +843,7 @@ dependencies = [ "linked-hash-map", "log", "names", - "near-abi", + "near-abi 0.4.0", "near-cli-rs", "near-crypto 0.17.0", "near-jsonrpc-client", @@ -840,7 +864,7 @@ dependencies = [ name = "cargo-near-integration-tests" version = "0.1.0" dependencies = [ - "borsh 0.9.3", + "borsh 1.1.0", "camino", "cargo-near 0.4.1", "clap 4.4.6", @@ -849,7 +873,7 @@ dependencies = [ "function_name", "git2", "minifier", - "near-abi", + "near-abi 0.4.0", "near-workspaces", "prettyplease", "proc-macro2", @@ -928,6 +952,12 @@ version = "1.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" +[[package]] +name = "cfg_aliases" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fd16c4719339c4530435d38e511904438d07cce7950afa3718a84ac36c10e89e" + [[package]] name = "chrono" version = "0.4.31" @@ -2794,6 +2824,18 @@ dependencies = [ "serde", ] +[[package]] +name = "near-abi" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5bd176820187cfb134a5147330fe803357bf5dab9a14f891d1702beb3d471dfb" +dependencies = [ + "borsh 1.1.0", + "schemars", + "semver", + "serde", +] + [[package]] name = "near-account-id" version = "0.14.0" @@ -3219,7 +3261,7 @@ dependencies = [ "base64 0.13.1", "borsh 0.9.3", "bs58 0.4.0", - "near-abi", + "near-abi 0.3.0", "near-crypto 0.14.0", "near-primitives 0.14.0", "near-primitives-core 0.14.0", @@ -5050,6 +5092,18 @@ dependencies = [ "unicode-ident", ] +[[package]] +name = "syn_derive" +version = "0.1.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1329189c02ff984e9736652b1631330da25eaa6bc639089ed4915d25446cbe7b" +dependencies = [ + "proc-macro-error", + "proc-macro2", + "quote", + "syn 2.0.38", +] + [[package]] name = "system-configuration" version = "0.5.1" diff --git a/cargo-near/Cargo.toml b/cargo-near/Cargo.toml index a4083f66..e0904470 100644 --- a/cargo-near/Cargo.toml +++ b/cargo-near/Cargo.toml @@ -28,7 +28,7 @@ serde_json = "1.0" sha2 = "0.10" symbolic-debuginfo = "8.8" schemars = "0.8" -near-abi = { version = "0.3.0", features = ["__chunked-entries"] } +near-abi = { version = "0.4.0", features = ["__chunked-entries"] } libloading = "0.7.3" zstd = "0.11" atty = "0.2.14" diff --git a/integration-tests/Cargo.toml b/integration-tests/Cargo.toml index fcf97a7f..98ee9060 100644 --- a/integration-tests/Cargo.toml +++ b/integration-tests/Cargo.toml @@ -6,10 +6,10 @@ publish = false [dependencies] const_format = "0.2" -near-abi = "0.3.0" +near-abi = "0.4.0" [dev-dependencies] -borsh = "0.9" +borsh = { version = "1.0.0", features = ["derive", "unstable__schema"]} camino = "1.1.1" cargo-near = { path = "../cargo-near" } color-eyre = "0.6" diff --git a/integration-tests/src/lib.rs b/integration-tests/src/lib.rs index 15688551..45554663 100644 --- a/integration-tests/src/lib.rs +++ b/integration-tests/src/lib.rs @@ -1,11 +1,17 @@ use const_format::formatcp; -pub const SDK_VERSION: &str = "4.1.0"; -pub const SDK_GIT_REV: &str = "10b0dea3b1a214d789cc90314aa814a4181610ad"; +/// published `near-sdk` version +pub const SDK_VERSION: &str = "4.1.1"; +/// NOTE: this version is version of near-sdk in master branch from 5.x.x development cycle +pub const SDK_VERSION_MASTER: &str = "4.1.1"; +pub const SDK_GIT_REV: &str = "15bfb0e6d54ff386478d137074027c2cb863df03"; pub const SDK_VERSION_TOML: &str = formatcp!(r#"version = "{SDK_VERSION}""#); +pub const SDK_GIT_VERSION_TOML_COMMA: &str = formatcp!( + r#"version = "{SDK_VERSION_MASTER}", git = "https://github.com/near/near-sdk-rs.git", rev = "{SDK_GIT_REV}""# +); pub const SDK_GIT_VERSION_TOML_TABLE: &str = formatcp!( r#" - version = "{SDK_VERSION}" + version = "{SDK_VERSION_MASTER}" git = "https://github.com/near/near-sdk-rs.git" rev = "{SDK_GIT_REV}" "# @@ -27,6 +33,7 @@ macro_rules! invoke_cargo_near { cargo_vars.insert("sdk-version", $crate::SDK_VERSION); cargo_vars.insert("sdk-git-rev", $crate::SDK_GIT_REV); cargo_vars.insert("sdk-version-toml", $crate::SDK_VERSION_TOML); + cargo_vars.insert("sdk-git-version-toml-comma", $crate::SDK_GIT_VERSION_TOML_COMMA); cargo_vars.insert("sdk-git-version-toml-table", $crate::SDK_GIT_VERSION_TOML_TABLE); cargo_vars.insert("name", function_name!()); for (k, v) in cargo_vars { @@ -111,15 +118,12 @@ macro_rules! generate_abi_fn_with { $crate::generate_abi_with! { $(Cargo: $cargo_path;)? $(Vars: $cargo_vars;)? $(Opts: $cli_opts;)? Code: - // fixme! remove after borsh fixes trait qualification - // fixme! https://github.com/near/borsh-rs/issues/112 - use near_sdk::borsh::BorshSchema; - - use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; + use near_sdk::borsh::{BorshDeserialize, BorshSerialize}; use near_sdk::near_bindgen; #[near_bindgen] #[derive(Default, BorshDeserialize, BorshSerialize)] + #[borsh(crate = "near_sdk::borsh")] pub struct Contract {} #[near_bindgen] @@ -210,11 +214,12 @@ macro_rules! build_fn_with { $crate::build_with! { $(Cargo: $cargo_path;)? $(Vars: $cargo_vars;)? $(Opts: $cli_opts;)? Code: - use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; + use near_sdk::borsh::{BorshDeserialize, BorshSerialize}; use near_sdk::{near_bindgen, NearSchema}; #[near_bindgen] #[derive(Default, BorshDeserialize, BorshSerialize)] + #[borsh(crate = "near_sdk::borsh")] pub struct Contract {} #[near_bindgen] diff --git a/integration-tests/templates/_Cargo.toml b/integration-tests/templates/_Cargo.toml index 19ba358f..902b561f 100644 --- a/integration-tests/templates/_Cargo.toml +++ b/integration-tests/templates/_Cargo.toml @@ -7,7 +7,9 @@ edition = "2021" crate-type = ["cdylib"] [dependencies] -near-sdk = { features = ["unstable"], ::sdk-version-toml:: } +# NOTE: uncomment line 11 and comment 12, if it's desirable to switch to published `near-sdk` version +# near-sdk = { features = ["unstable"], ::sdk-version-toml:: } +near-sdk = { features = ["unstable"], ::sdk-git-version-toml-comma:: } serde = { version = "1", features = ["derive"] } schemars = "0.8" diff --git a/integration-tests/templates/negative/_Cargo_no_abi_feature.toml b/integration-tests/templates/negative/_Cargo_no_abi_feature.toml index 8ceeaa5d..f3a4fc9c 100644 --- a/integration-tests/templates/negative/_Cargo_no_abi_feature.toml +++ b/integration-tests/templates/negative/_Cargo_no_abi_feature.toml @@ -7,7 +7,9 @@ edition = "2021" crate-type = ["cdylib"] [dependencies] -near-sdk = { default-features = false, version = "::sdk-version::" } +# NOTE: uncomment line 11 and comment 12, if it's desirable to switch to published `near-sdk` version +# near-sdk = { default-features = false, ::sdk-version-toml:: } +near-sdk = { default-features = false, ::sdk-git-version-toml-comma:: } serde = { version = "1", features = ["derive"] } schemars = "0.8" diff --git a/integration-tests/templates/sdk-dependency/_Cargo_explicit.toml b/integration-tests/templates/sdk-dependency/_Cargo_explicit.toml index 87cc9472..0787b39a 100644 --- a/integration-tests/templates/sdk-dependency/_Cargo_explicit.toml +++ b/integration-tests/templates/sdk-dependency/_Cargo_explicit.toml @@ -7,7 +7,9 @@ edition = "2021" crate-type = ["cdylib"] [dependencies] -near-sdk = { features = ["abi"], ::sdk-version-toml:: } +# NOTE: uncomment line 11 and comment 12, if it's desirable to switch to published `near-sdk` version +# near-sdk = { features = ["abi"], ::sdk-version-toml:: } +near-sdk = { features = ["abi"], ::sdk-git-version-toml-comma:: } serde = { version = "1", features = ["derive"] } schemars = "0.8" diff --git a/integration-tests/templates/sdk-dependency/_Cargo_local_path_with_version.toml b/integration-tests/templates/sdk-dependency/_Cargo_local_path_with_version.toml index 59c5a48f..a9addca6 100644 --- a/integration-tests/templates/sdk-dependency/_Cargo_local_path_with_version.toml +++ b/integration-tests/templates/sdk-dependency/_Cargo_local_path_with_version.toml @@ -7,7 +7,7 @@ edition = "2021" crate-type = ["cdylib"] [dependencies] -near-sdk = { path = "::path::", version = "::sdk-version::" } +near-sdk = { path = "::path::", ::sdk-version-toml:: } serde = { version = "1", features = ["derive"] } schemars = "0.8" diff --git a/integration-tests/templates/sdk-dependency/_Cargo_multiple_features.toml b/integration-tests/templates/sdk-dependency/_Cargo_multiple_features.toml index 386369c7..67707745 100644 --- a/integration-tests/templates/sdk-dependency/_Cargo_multiple_features.toml +++ b/integration-tests/templates/sdk-dependency/_Cargo_multiple_features.toml @@ -7,7 +7,9 @@ edition = "2021" crate-type = ["cdylib"] [dependencies] -near-sdk = { features = ["abi", "unstable"], ::sdk-version-toml:: } +# NOTE: uncomment line 11 and comment 12, if it's desirable to switch to published `near-sdk` version +# near-sdk = { features = ["abi", "unstable"], ::sdk-version-toml:: } +near-sdk = { features = ["abi", "unstable"], ::sdk-git-version-toml-comma:: } serde = { version = "1", features = ["derive"] } schemars = "0.8" diff --git a/integration-tests/templates/sdk-dependency/_Cargo_no_default_features.toml b/integration-tests/templates/sdk-dependency/_Cargo_no_default_features.toml index 54ae89ae..546ca1c5 100644 --- a/integration-tests/templates/sdk-dependency/_Cargo_no_default_features.toml +++ b/integration-tests/templates/sdk-dependency/_Cargo_no_default_features.toml @@ -7,7 +7,9 @@ edition = "2021" crate-type = ["cdylib"] [dependencies] -near-sdk = { default-features = false, features = ["abi"], ::sdk-version-toml:: } +# NOTE: uncomment line 11 and comment 12, if it's desirable to switch to published `near-sdk` version +# near-sdk = { default-features = false, features = ["abi"], ::sdk-version-toml:: } +near-sdk = { default-features = false, features = ["abi"], ::sdk-git-version-toml-comma:: } serde = { version = "1", features = ["derive"] } schemars = "0.8" diff --git a/integration-tests/templates/sdk-dependency/_Cargo_platform_specific.toml b/integration-tests/templates/sdk-dependency/_Cargo_platform_specific.toml index 0c1dff62..d1d2cc10 100644 --- a/integration-tests/templates/sdk-dependency/_Cargo_platform_specific.toml +++ b/integration-tests/templates/sdk-dependency/_Cargo_platform_specific.toml @@ -11,10 +11,14 @@ serde = { version = "1", features = ["derive"] } schemars = "0.8" [target.'cfg(windows)'.dependencies] -near-sdk = { ::sdk-version-toml:: } +# NOTE: uncomment line 15 and comment 16, if it's desirable to switch to published `near-sdk` version +# near-sdk = { ::sdk-version-toml:: } +near-sdk = { ::sdk-git-version-toml-comma:: } [target.'cfg(unix)'.dependencies] -near-sdk = { ::sdk-version-toml:: } +# NOTE: uncomment line 20 and comment 21, if it's desirable to switch to published `near-sdk` version +# near-sdk = { ::sdk-version-toml:: } +near-sdk = { ::sdk-git-version-toml-comma:: } [workspace] members = [] diff --git a/integration-tests/tests/abi/borsh_schema.rs b/integration-tests/tests/abi/borsh_schema.rs index 4648dc79..50420da9 100644 --- a/integration-tests/tests/abi/borsh_schema.rs +++ b/integration-tests/tests/abi/borsh_schema.rs @@ -2,7 +2,7 @@ use crate::util::AsBorshSchema; use borsh::schema::{BorshSchemaContainer, Definition, Fields}; use cargo_near_integration_tests::{generate_abi, generate_abi_fn}; use function_name::named; -use std::collections::HashMap; +use std::collections::BTreeMap; #[test] #[named] @@ -14,44 +14,42 @@ fn test_borsh_schema_numeric_primitives_signed() -> cargo_near::CliResult { #[serializer(borsh)] b: i16, #[serializer(borsh)] c: i32, #[serializer(borsh)] d: i64, - #[serializer(borsh)] e: i128 + #[serializer(borsh)] e: i128, + #[serializer(borsh)] f: isize ) {} }; assert_eq!(abi_root.body.functions.len(), 1); let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; - assert_eq!(params.len(), 5); - let i8_schema = BorshSchemaContainer { - declaration: "i8".to_string(), - definitions: HashMap::new(), - }; - let i16_schema = BorshSchemaContainer { - declaration: "i16".to_string(), - definitions: HashMap::new(), - }; - let i32_schema = BorshSchemaContainer { - declaration: "i32".to_string(), - definitions: HashMap::new(), - }; - let i64_schema = BorshSchemaContainer { - declaration: "i64".to_string(), - definitions: HashMap::new(), - }; - let i128_schema = BorshSchemaContainer { - declaration: "i128".to_string(), - definitions: HashMap::new(), - }; - // borsh-rs does not support isize schema; need https://github.com/near/borsh-rs/pull/99 to come in first - // let isize_schema = BorshSchemaContainer { - // declaration: "i64".to_string(), - // definitions: HashMap::new(), - // }; + assert_eq!(params.len(), 6); + let i8_schema = BorshSchemaContainer::new( + "i8".to_string(), + BTreeMap::from([("i8".to_string(), Definition::Primitive(1))]), + ); + let i16_schema = BorshSchemaContainer::new( + "i16".to_string(), + BTreeMap::from([("i16".to_string(), Definition::Primitive(2))]), + ); + let i32_schema = BorshSchemaContainer::new( + "i32".to_string(), + BTreeMap::from([("i32".to_string(), Definition::Primitive(4))]), + ); + let i64_schema = BorshSchemaContainer::new( + "i64".to_string(), + BTreeMap::from([("i64".to_string(), Definition::Primitive(8))]), + ); + let i128_schema = BorshSchemaContainer::new( + "i128".to_string(), + BTreeMap::from([("i128".to_string(), Definition::Primitive(16))]), + ); + let isize_schema = &i64_schema; assert_eq!(¶ms[0].type_schema, &i8_schema); assert_eq!(¶ms[1].type_schema, &i16_schema); assert_eq!(¶ms[2].type_schema, &i32_schema); assert_eq!(¶ms[3].type_schema, &i64_schema); assert_eq!(¶ms[4].type_schema, &i128_schema); + assert_eq!(¶ms[5].type_schema, isize_schema); Ok(()) } @@ -66,44 +64,42 @@ fn test_borsh_schema_numeric_primitives_unsigned() -> cargo_near::CliResult { #[serializer(borsh)] b: u16, #[serializer(borsh)] c: u32, #[serializer(borsh)] d: u64, - #[serializer(borsh)] e: u128 + #[serializer(borsh)] e: u128, + #[serializer(borsh)] f: usize ) {} }; assert_eq!(abi_root.body.functions.len(), 1); let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; - assert_eq!(params.len(), 5); - let u8_schema = BorshSchemaContainer { - declaration: "u8".to_string(), - definitions: HashMap::new(), - }; - let u16_schema = BorshSchemaContainer { - declaration: "u16".to_string(), - definitions: HashMap::new(), - }; - let u32_schema = BorshSchemaContainer { - declaration: "u32".to_string(), - definitions: HashMap::new(), - }; - let u64_schema = BorshSchemaContainer { - declaration: "u64".to_string(), - definitions: HashMap::new(), - }; - let u128_schema = BorshSchemaContainer { - declaration: "u128".to_string(), - definitions: HashMap::new(), - }; - // borsh-rs does not support usize schema; need https://github.com/near/borsh-rs/pull/99 to come in first - // let usize_schema = BorshSchemaContainer { - // declaration: "u64".to_string(), - // definitions: HashMap::new(), - // }; + assert_eq!(params.len(), 6); + let u8_schema = BorshSchemaContainer::new( + "u8".to_string(), + BTreeMap::from([("u8".to_string(), Definition::Primitive(1))]), + ); + let u16_schema = BorshSchemaContainer::new( + "u16".to_string(), + BTreeMap::from([("u16".to_string(), Definition::Primitive(2))]), + ); + let u32_schema = BorshSchemaContainer::new( + "u32".to_string(), + BTreeMap::from([("u32".to_string(), Definition::Primitive(4))]), + ); + let u64_schema = BorshSchemaContainer::new( + "u64".to_string(), + BTreeMap::from([("u64".to_string(), Definition::Primitive(8))]), + ); + let u128_schema = BorshSchemaContainer::new( + "u128".to_string(), + BTreeMap::from([("u128".to_string(), Definition::Primitive(16))]), + ); + let usize_schema = &u64_schema; assert_eq!(¶ms[0].type_schema, &u8_schema); assert_eq!(¶ms[1].type_schema, &u16_schema); assert_eq!(¶ms[2].type_schema, &u32_schema); assert_eq!(¶ms[3].type_schema, &u64_schema); assert_eq!(¶ms[4].type_schema, &u128_schema); + assert_eq!(¶ms[5].type_schema, usize_schema); Ok(()) } @@ -119,14 +115,14 @@ fn test_borsh_schema_numeric_primitives_float() -> cargo_near::CliResult { let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; assert_eq!(params.len(), 2); - let f32_schema = BorshSchemaContainer { - declaration: "f32".to_string(), - definitions: HashMap::new(), - }; - let f64_schema = BorshSchemaContainer { - declaration: "f64".to_string(), - definitions: HashMap::new(), - }; + let f32_schema = BorshSchemaContainer::new( + "f32".to_string(), + BTreeMap::from([("f32".to_string(), Definition::Primitive(4))]), + ); + let f64_schema = BorshSchemaContainer::new( + "f64".to_string(), + BTreeMap::from([("f64".to_string(), Definition::Primitive(8))]), + ); assert_eq!(¶ms[0].type_schema, &f32_schema); assert_eq!(¶ms[1].type_schema, &f64_schema); @@ -144,10 +140,20 @@ fn test_borsh_schema_string() -> cargo_near::CliResult { let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; assert_eq!(params.len(), 3); - let string_schema = BorshSchemaContainer { - declaration: "string".to_string(), - definitions: HashMap::new(), - }; + let string_schema = BorshSchemaContainer::new( + "String".to_string(), + BTreeMap::from([ + ( + "String".to_string(), + Definition::Sequence { + length_width: Definition::DEFAULT_LENGTH_WIDTH, + length_range: Definition::DEFAULT_LENGTH_RANGE, + elements: "u8".to_string(), + }, + ), + ("u8".to_string(), Definition::Primitive(1)), + ]), + ); assert_eq!(¶ms[0].type_schema, &string_schema); assert_eq!(¶ms[1].type_schema, &string_schema); assert_eq!(¶ms[2].type_schema, &string_schema); @@ -169,16 +175,16 @@ fn test_borsh_schema_other_primitives() -> cargo_near::CliResult { // char is unsupported by borsh spec // let char_schema = BorshSchemaContainer { // declaration: "char".to_string(), - // definitions: HashMap::new(), + // definitions: BTreeMap::new(), // }; - let bool_schema = BorshSchemaContainer { - declaration: "bool".to_string(), - definitions: HashMap::new(), - }; - let unit_schema = BorshSchemaContainer { - declaration: "nil".to_string(), - definitions: HashMap::new(), - }; + let bool_schema = BorshSchemaContainer::new( + "bool".to_string(), + BTreeMap::from([("bool".to_string(), Definition::Primitive(1))]), + ); + let unit_schema = BorshSchemaContainer::new( + "()".to_string(), + BTreeMap::from([("()".to_string(), Definition::Primitive(0))]), + ); assert_eq!(¶ms[0].type_schema, &bool_schema); assert_eq!(¶ms[1].type_schema, &unit_schema); @@ -191,6 +197,7 @@ fn test_borsh_schema_tuples() -> cargo_near::CliResult { let abi_root = generate_abi_fn! { pub fn foo( &self, + #[serializer(borsh)] a: (bool,), #[serializer(borsh)] b: (bool, bool), #[serializer(borsh)] c: (bool, bool, bool) ) {} @@ -199,32 +206,46 @@ fn test_borsh_schema_tuples() -> cargo_near::CliResult { assert_eq!(abi_root.body.functions.len(), 1); let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; - assert_eq!(params.len(), 2); - // Needs https://github.com/near/borsh-rs/pull/100 to come in first - // let tuple1_schema = BorshSchemaContainer { - // declaration: "Tuple".to_string(), - // definitions: HashMap::new(), - // }; - let tuple2_schema = BorshSchemaContainer { - declaration: "Tuple".to_string(), - definitions: HashMap::from([( - "Tuple".to_string(), - Definition::Tuple { - elements: vec!["bool".to_string(), "bool".to_string()], - }, - )]), - }; - let tuple3_schema = BorshSchemaContainer { - declaration: "Tuple".to_string(), - definitions: HashMap::from([( - "Tuple".to_string(), - Definition::Tuple { - elements: vec!["bool".to_string(), "bool".to_string(), "bool".to_string()], - }, - )]), - }; - assert_eq!(¶ms[0].type_schema, &tuple2_schema); - assert_eq!(¶ms[1].type_schema, &tuple3_schema); + assert_eq!(params.len(), 3); + let tuple1_schema = BorshSchemaContainer::new( + "(bool,)".to_string(), + BTreeMap::from([ + ( + "(bool,)".to_string(), + Definition::Tuple { + elements: vec!["bool".to_string()], + }, + ), + ("bool".to_string(), Definition::Primitive(1)), + ]), + ); + let tuple2_schema = BorshSchemaContainer::new( + "(bool, bool)".to_string(), + BTreeMap::from([ + ( + "(bool, bool)".to_string(), + Definition::Tuple { + elements: vec!["bool".to_string(), "bool".to_string()], + }, + ), + ("bool".to_string(), Definition::Primitive(1)), + ]), + ); + let tuple3_schema = BorshSchemaContainer::new( + "(bool, bool, bool)".to_string(), + BTreeMap::from([ + ( + "(bool, bool, bool)".to_string(), + Definition::Tuple { + elements: vec!["bool".to_string(), "bool".to_string(), "bool".to_string()], + }, + ), + ("bool".to_string(), Definition::Primitive(1)), + ]), + ); + assert_eq!(¶ms[0].type_schema, &tuple1_schema); + assert_eq!(¶ms[1].type_schema, &tuple2_schema); + assert_eq!(¶ms[2].type_schema, &tuple3_schema); Ok(()) } @@ -245,35 +266,48 @@ fn test_borsh_schema_arrays() -> cargo_near::CliResult { let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; assert_eq!(params.len(), 3); - let array8_schema = BorshSchemaContainer { - declaration: "Array".to_string(), - definitions: HashMap::from([( - "Array".to_string(), - Definition::Array { - length: 8, - elements: "bool".to_string(), - }, - )]), - }; - let array16_schema = BorshSchemaContainer { - declaration: "Array".to_string(), - definitions: HashMap::from([( - "Array".to_string(), - Definition::Array { - length: 16, - elements: "bool".to_string(), - }, - )]), - }; - let array_unlim_schema = BorshSchemaContainer { - declaration: "Vec".to_string(), - definitions: HashMap::from([( - "Vec".to_string(), - Definition::Sequence { - elements: "bool".to_string(), - }, - )]), - }; + let array8_schema = BorshSchemaContainer::new( + "[bool; 8]".to_string(), + BTreeMap::from([ + ( + "[bool; 8]".to_string(), + Definition::Sequence { + length_width: Definition::ARRAY_LENGTH_WIDTH, + length_range: 8..=8, + elements: "bool".to_string(), + }, + ), + ("bool".to_string(), Definition::Primitive(1)), + ]), + ); + let array16_schema = BorshSchemaContainer::new( + "[bool; 16]".to_string(), + BTreeMap::from([ + ( + "[bool; 16]".to_string(), + Definition::Sequence { + length_width: Definition::ARRAY_LENGTH_WIDTH, + length_range: 16..=16, + elements: "bool".to_string(), + }, + ), + ("bool".to_string(), Definition::Primitive(1)), + ]), + ); + let array_unlim_schema = BorshSchemaContainer::new( + "Vec".to_string(), + BTreeMap::from([ + ( + "Vec".to_string(), + Definition::Sequence { + length_width: Definition::DEFAULT_LENGTH_WIDTH, + length_range: Definition::DEFAULT_LENGTH_RANGE, + elements: "bool".to_string(), + }, + ), + ("bool".to_string(), Definition::Primitive(1)), + ]), + ); assert_eq!(¶ms[0].type_schema, &array8_schema); assert_eq!(¶ms[1].type_schema, &array16_schema); assert_eq!(¶ms[2].type_schema, &array_unlim_schema); @@ -285,19 +319,17 @@ fn test_borsh_schema_arrays() -> cargo_near::CliResult { #[named] fn test_borsh_schema_struct() -> cargo_near::CliResult { let abi_root = generate_abi! { - // fixme! remove after borsh fixes trait qualification - // fixme! https://github.com/near/borsh-rs/issues/112 - use near_sdk::borsh::BorshSchema; - - use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; + use near_sdk::borsh::{BorshDeserialize, BorshSerialize}; use near_sdk::{near_bindgen, NearSchema}; #[derive(NearSchema, BorshSerialize, BorshDeserialize)] #[abi(borsh)] + #[borsh(crate = "near_sdk::borsh")] pub struct Pair(u32, u32); #[derive(NearSchema, BorshSerialize, BorshDeserialize)] #[abi(borsh)] + #[borsh(crate = "near_sdk::borsh")] pub struct PairNamed { first: u32, second: u32 @@ -305,6 +337,7 @@ fn test_borsh_schema_struct() -> cargo_near::CliResult { #[near_bindgen] #[derive(Default, BorshDeserialize, BorshSerialize)] + #[borsh(crate = "near_sdk::borsh")] pub struct Contract {} #[near_bindgen] @@ -317,27 +350,33 @@ fn test_borsh_schema_struct() -> cargo_near::CliResult { let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; assert_eq!(params.len(), 2); - let pair_def_schema = BorshSchemaContainer { - declaration: "Pair".to_string(), - definitions: HashMap::from([( - "Pair".to_string(), - Definition::Struct { - fields: Fields::UnnamedFields(vec!["u32".to_string(), "u32".to_string()]), - }, - )]), - }; - let pair_named_def_schema = BorshSchemaContainer { - declaration: "PairNamed".to_string(), - definitions: HashMap::from([( - "PairNamed".to_string(), - Definition::Struct { - fields: Fields::NamedFields(vec![ - ("first".to_string(), "u32".to_string()), - ("second".to_string(), "u32".to_string()), - ]), - }, - )]), - }; + let pair_def_schema = BorshSchemaContainer::new( + "Pair".to_string(), + BTreeMap::from([ + ( + "Pair".to_string(), + Definition::Struct { + fields: Fields::UnnamedFields(vec!["u32".to_string(), "u32".to_string()]), + }, + ), + ("u32".to_string(), Definition::Primitive(4)), + ]), + ); + let pair_named_def_schema = BorshSchemaContainer::new( + "PairNamed".to_string(), + BTreeMap::from([ + ( + "PairNamed".to_string(), + Definition::Struct { + fields: Fields::NamedFields(vec![ + ("first".to_string(), "u32".to_string()), + ("second".to_string(), "u32".to_string()), + ]), + }, + ), + ("u32".to_string(), Definition::Primitive(4)), + ]), + ); assert_eq!(¶ms[0].type_schema, &pair_def_schema); assert_eq!(¶ms[1].type_schema, &pair_named_def_schema); @@ -348,15 +387,12 @@ fn test_borsh_schema_struct() -> cargo_near::CliResult { #[named] fn test_borsh_schema_enum() -> cargo_near::CliResult { let abi_root = generate_abi! { - // fixme! remove after borsh fixes trait qualification - // fixme! https://github.com/near/borsh-rs/issues/112 - use near_sdk::borsh::BorshSchema; - - use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; + use near_sdk::borsh::{BorshDeserialize, BorshSerialize}; use near_sdk::{near_bindgen, NearSchema}; #[derive(NearSchema, BorshSerialize, BorshDeserialize)] #[abi(borsh)] + #[borsh(crate = "near_sdk::borsh")] pub enum IpAddrKind { V4, V6, @@ -364,6 +400,7 @@ fn test_borsh_schema_enum() -> cargo_near::CliResult { #[derive(NearSchema, BorshSerialize, BorshDeserialize)] #[abi(borsh)] + #[borsh(crate = "near_sdk::borsh")] pub enum IpAddr { V4(u8, u8, u8, u8), V6(String), @@ -371,6 +408,7 @@ fn test_borsh_schema_enum() -> cargo_near::CliResult { #[near_bindgen] #[derive(Default, BorshDeserialize, BorshSerialize)] + #[borsh(crate = "near_sdk::borsh")] pub struct Contract {} #[near_bindgen] @@ -383,15 +421,16 @@ fn test_borsh_schema_enum() -> cargo_near::CliResult { let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; assert_eq!(params.len(), 2); - let ip_addr_kind_def_schema = BorshSchemaContainer { - declaration: "IpAddrKind".to_string(), - definitions: HashMap::from([ + let ip_addr_kind_def_schema = BorshSchemaContainer::new( + "IpAddrKind".to_string(), + BTreeMap::from([ ( "IpAddrKind".to_string(), Definition::Enum { + tag_width: 1, variants: vec![ - ("V4".to_string(), "IpAddrKindV4".to_string()), - ("V6".to_string(), "IpAddrKindV6".to_string()), + (0, "V4".to_string(), "IpAddrKindV4".to_string()), + (1, "V6".to_string(), "IpAddrKindV6".to_string()), ], }, ), @@ -408,16 +447,17 @@ fn test_borsh_schema_enum() -> cargo_near::CliResult { }, ), ]), - }; - let ip_addr_def_schema = BorshSchemaContainer { - declaration: "IpAddr".to_string(), - definitions: HashMap::from([ + ); + let ip_addr_def_schema = BorshSchemaContainer::new( + "IpAddr".to_string(), + BTreeMap::from([ ( "IpAddr".to_string(), Definition::Enum { + tag_width: 1, variants: vec![ - ("V4".to_string(), "IpAddrV4".to_string()), - ("V6".to_string(), "IpAddrV6".to_string()), + (0, "V4".to_string(), "IpAddrV4".to_string()), + (1, "V6".to_string(), "IpAddrV6".to_string()), ], }, ), @@ -435,11 +475,20 @@ fn test_borsh_schema_enum() -> cargo_near::CliResult { ( "IpAddrV6".to_string(), Definition::Struct { - fields: Fields::UnnamedFields(vec!["string".to_string()]), + fields: Fields::UnnamedFields(vec!["String".to_string()]), }, ), + ( + "String".to_string(), + Definition::Sequence { + length_width: Definition::DEFAULT_LENGTH_WIDTH, + length_range: Definition::DEFAULT_LENGTH_RANGE, + elements: "u8".to_string(), + }, + ), + ("u8".to_string(), Definition::Primitive(1)), ]), - }; + ); assert_eq!(¶ms[0].type_schema, &ip_addr_kind_def_schema); assert_eq!(¶ms[1].type_schema, &ip_addr_def_schema); @@ -450,15 +499,12 @@ fn test_borsh_schema_enum() -> cargo_near::CliResult { #[named] fn test_borsh_schema_complex() -> cargo_near::CliResult { let abi_root = generate_abi! { - // fixme! remove after borsh fixes trait qualification - // fixme! https://github.com/near/borsh-rs/issues/112 - use near_sdk::borsh::BorshSchema; - - use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; + use near_sdk::borsh::{BorshDeserialize, BorshSerialize}; use near_sdk::{near_bindgen, NearSchema}; #[derive(NearSchema, BorshSerialize, BorshDeserialize)] #[abi(borsh)] + #[borsh(crate = "near_sdk::borsh")] pub enum IpAddrKind { V4, V6, @@ -466,6 +512,7 @@ fn test_borsh_schema_complex() -> cargo_near::CliResult { #[derive(NearSchema, BorshSerialize, BorshDeserialize)] #[abi(borsh)] + #[borsh(crate = "near_sdk::borsh")] pub struct IpAddr { kind: IpAddrKind, address: String, @@ -473,6 +520,7 @@ fn test_borsh_schema_complex() -> cargo_near::CliResult { #[near_bindgen] #[derive(Default, BorshDeserialize, BorshSerialize)] + #[borsh(crate = "near_sdk::borsh")] pub struct Contract {} #[near_bindgen] @@ -485,24 +533,25 @@ fn test_borsh_schema_complex() -> cargo_near::CliResult { let function = &abi_root.body.functions[0]; let params = function.params.borsh_schemas()?; assert_eq!(params.len(), 1); - let ip_addr_def_schema = BorshSchemaContainer { - declaration: "IpAddr".to_string(), - definitions: HashMap::from([ + let ip_addr_def_schema = BorshSchemaContainer::new( + "IpAddr".to_string(), + BTreeMap::from([ ( "IpAddr".to_string(), Definition::Struct { fields: Fields::NamedFields(vec![ ("kind".to_string(), "IpAddrKind".to_string()), - ("address".to_string(), "string".to_string()), + ("address".to_string(), "String".to_string()), ]), }, ), ( "IpAddrKind".to_string(), Definition::Enum { + tag_width: 1, variants: vec![ - ("V4".to_string(), "IpAddrKindV4".to_string()), - ("V6".to_string(), "IpAddrKindV6".to_string()), + (0, "V4".to_string(), "IpAddrKindV4".to_string()), + (1, "V6".to_string(), "IpAddrKindV6".to_string()), ], }, ), @@ -518,8 +567,17 @@ fn test_borsh_schema_complex() -> cargo_near::CliResult { fields: Fields::Empty, }, ), + ( + "String".to_string(), + Definition::Sequence { + length_width: Definition::DEFAULT_LENGTH_WIDTH, + length_range: Definition::DEFAULT_LENGTH_RANGE, + elements: "u8".to_string(), + }, + ), + ("u8".to_string(), Definition::Primitive(1)), ]), - }; + ); assert_eq!(¶ms[0].type_schema, &ip_addr_def_schema); Ok(()) diff --git a/integration-tests/tests/abi/json_schema.rs b/integration-tests/tests/abi/json_schema.rs index 1eee10d1..2932e091 100644 --- a/integration-tests/tests/abi/json_schema.rs +++ b/integration-tests/tests/abi/json_schema.rs @@ -386,7 +386,7 @@ fn test_schema_arrays() -> cargo_near::CliResult { #[named] fn test_schema_struct() -> cargo_near::CliResult { let abi_root = generate_abi! { - use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; + use near_sdk::borsh::{BorshDeserialize, BorshSerialize}; use near_sdk::{near_bindgen, NearSchema}; use near_sdk::serde::{Deserialize, Serialize}; @@ -403,6 +403,7 @@ fn test_schema_struct() -> cargo_near::CliResult { #[near_bindgen] #[derive(Default, BorshDeserialize, BorshSerialize)] + #[borsh(crate = "near_sdk::borsh")] pub struct Contract {} #[near_bindgen] @@ -491,7 +492,7 @@ fn test_schema_struct() -> cargo_near::CliResult { #[named] fn test_schema_enum() -> cargo_near::CliResult { let abi_root = generate_abi! { - use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; + use near_sdk::borsh::{BorshDeserialize, BorshSerialize}; use near_sdk::{near_bindgen, NearSchema}; use near_sdk::serde::{Deserialize, Serialize}; @@ -511,6 +512,7 @@ fn test_schema_enum() -> cargo_near::CliResult { #[near_bindgen] #[derive(Default, BorshDeserialize, BorshSerialize)] + #[borsh(crate = "near_sdk::borsh")] pub struct Contract {} #[near_bindgen] @@ -623,7 +625,7 @@ fn test_schema_enum() -> cargo_near::CliResult { #[named] fn test_schema_complex() -> cargo_near::CliResult { let abi_root = generate_abi! { - use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize}; + use near_sdk::borsh::{BorshDeserialize, BorshSerialize}; use near_sdk::{near_bindgen, NearSchema}; use near_sdk::serde::{Deserialize, Serialize}; @@ -643,6 +645,7 @@ fn test_schema_complex() -> cargo_near::CliResult { #[near_bindgen] #[derive(Default, BorshDeserialize, BorshSerialize)] + #[borsh(crate = "near_sdk::borsh")] pub struct Contract {} #[near_bindgen] diff --git a/integration-tests/tests/cargo/mod.rs b/integration-tests/tests/cargo/mod.rs index 32d7052e..5ae45065 100644 --- a/integration-tests/tests/cargo/mod.rs +++ b/integration-tests/tests/cargo/mod.rs @@ -196,7 +196,11 @@ fn test_dependency_patch() -> cargo_near::CliResult { Ok(()) } +/// this is a test of Cargo.toml format +/// TODO: un-ignore when `5.x.x` near-sdk is published +/// and `cargo_near_integration_tests::SDK_VERSION` is changed 4.x.x -> 5.x.x #[test] +#[ignore] #[named] fn test_abi_not_a_table() -> cargo_near::CliResult { let abi_root = generate_abi_fn_with! {