| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203 |
- // SPDX-License-Identifier: Apache-2.0
- use crate::{account_new, build_solidity, BorshToken};
- use num_bigint::BigInt;
- use num_traits::{One, Zero};
- use std::slice;
- #[test]
- fn simple_mapping() {
- let mut vm = build_solidity(
- r#"
- contract foo {
- mapping (uint64 => uint64) map;
- function set(uint64 index, uint64 val) public {
- map[index] = val;
- }
- function get(uint64 index) public returns (uint64) {
- return map[index];
- }
- function rm(uint64 index) public {
- delete map[index];
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- for i in 0..10 {
- vm.function("set")
- .arguments(&[
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(300331 + i),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- }
- for i in 0..10 {
- let returns = vm
- .function("get")
- .arguments(&[BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(300331 + i)
- }
- );
- }
- let returns = vm
- .function("get")
- .arguments(&[BorshToken::Uint {
- width: 64,
- value: BigInt::from(101u8),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero()
- }
- );
- vm.function("rm")
- .arguments(&[BorshToken::Uint {
- width: 64,
- value: BigInt::from(104u8),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- for i in 0..10 {
- let returns = vm
- .function("get")
- .arguments(&[BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- if 102 + i != 104 {
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(300331 + i)
- }
- );
- } else {
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero(),
- }
- );
- }
- }
- }
- #[test]
- fn less_simple_mapping() {
- let mut vm = build_solidity(
- r#"
- struct S {
- string f1;
- int64[] f2;
- }
- contract foo {
- mapping (uint => S) map;
- function set_string(uint index, string s) public {
- map[index].f1 = s;
- }
- function add_int(uint index, int64 n) public {
- map[index].f2.push(n);
- }
- function get(uint index) public returns (S) {
- return map[index];
- }
- function rm(uint index) public {
- delete map[index];
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function(
- "set_string")
- .arguments(
- &[
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(12313132131321312311213131u128)
- },
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- ],
- )
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("add_int")
- .arguments(&[
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(12313132131321312311213131u128),
- },
- BorshToken::Int {
- width: 64,
- value: BigInt::from(102u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("get")
- .arguments(&[BorshToken::Uint {
- width: 256,
- value: BigInt::from(12313132131321312311213131u128),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Tuple(vec![
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- BorshToken::Array(vec![
- BorshToken::Int{
- width: 64,
- value: BigInt::from(102u8)
- },
- ]),
- ])
- );
- }
- #[test]
- fn string_mapping() {
- let mut vm = build_solidity(
- r#"
- struct S {
- string f1;
- int64[] f2;
- }
- contract foo {
- mapping (string => S) map;
- function set_string(string index, string s) public {
- map[index].f1 = s;
- }
- function add_int(string index, int64 n) public {
- map[index].f2.push(n);
- }
- function get(string index) public returns (S) {
- return map[index];
- }
- function rm(string index) public {
- delete map[index];
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function(
- "set_string")
- .arguments(
- &[
- BorshToken::String(String::from("a")),
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- ],
- )
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("add_int")
- .arguments(&[
- BorshToken::String(String::from("a")),
- BorshToken::Int {
- width: 64,
- value: BigInt::from(102u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("get")
- .arguments(&[BorshToken::String(String::from("a"))])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Tuple(vec![
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- BorshToken::Array(vec![
- BorshToken::Int{
- width: 64,
- value: BigInt::from(102u8)
- },
- ]),
- ])
- );
- }
- #[test]
- fn contract_mapping() {
- let mut vm = build_solidity(
- r#"
- contract foo {
- mapping (address => string) public map;
- function set(address index, string s) public {
- map[index] = s;
- }
- function get(address index) public returns (string) {
- return map[index];
- }
- function rm(address index) public {
- delete map[index];
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let index = BorshToken::Address(account_new());
- vm.function(
- "set")
- .arguments(
- &[
- index.clone(),
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- ], )
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("get")
- .arguments(slice::from_ref(&index))
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder"))
- );
- vm.function("rm")
- .arguments(slice::from_ref(&index))
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("get")
- .arguments(slice::from_ref(&index))
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(returns, BorshToken::String(String::from("")));
- }
- #[test]
- fn mapping_in_mapping() {
- let mut vm = build_solidity(
- r#"
- contract foo {
- mapping (string => mapping(int64 => byte)) public map;
- function set(string s, int64 n, bytes1 v) public {
- map[s][n] = v;
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("set")
- .arguments(&[
- BorshToken::String(String::from("a")),
- BorshToken::Int {
- width: 64,
- value: BigInt::from(102u8),
- },
- BorshToken::FixedBytes(vec![0x98]),
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("map")
- .arguments(&[
- BorshToken::String(String::from("a")),
- BorshToken::Int {
- width: 64,
- value: BigInt::from(102u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(returns, BorshToken::uint8_fixed_array(vec![0x98]));
- let returns = vm
- .function("map")
- .arguments(&[
- BorshToken::String(String::from("a")),
- BorshToken::Int {
- width: 64,
- value: BigInt::from(103u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(returns, BorshToken::uint8_fixed_array(vec![0]));
- let returns = vm
- .function("map")
- .arguments(&[
- BorshToken::String(String::from("b")),
- BorshToken::Int {
- width: 64,
- value: BigInt::from(102u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(returns, BorshToken::uint8_fixed_array(vec![0]));
- }
- #[test]
- fn sparse_array() {
- let mut vm = build_solidity(
- r#"
- struct S {
- string f1;
- int64[] f2;
- }
- contract foo {
- S[1e9] map;
- function set_string(uint index, string s) public {
- map[index].f1 = s;
- }
- function add_int(uint index, int64 n) public {
- map[index].f2.push(n);
- }
- function get(uint index) public returns (S) {
- return map[index];
- }
- function rm(uint index) public {
- delete map[index];
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function(
- "set_string")
- .arguments(
- &[
- BorshToken::Uint{
- width: 256,
- value: BigInt::from(909090909u64)
- },
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- ], )
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("add_int")
- .arguments(&[
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(909090909u64),
- },
- BorshToken::Int {
- width: 64,
- value: BigInt::from(102u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("get")
- .arguments(&[BorshToken::Uint {
- width: 256,
- value: BigInt::from(909090909u64),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Tuple(vec![
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- BorshToken::Array(vec![
- BorshToken::Int{
- width: 64,
- value: BigInt::from(102u8)
- },
- ]),
- ])
- );
- }
- #[test]
- fn massive_sparse_array() {
- let mut vm = build_solidity(
- r#"
- struct S {
- string f1;
- int64[] f2;
- }
- contract foo {
- S[1e24] map;
- function set_string(uint index, string s) public {
- map[index].f1 = s;
- }
- function add_int(uint index, int64 n) public {
- map[index].f2.push(n);
- }
- function get(uint index) public returns (S) {
- return map[index];
- }
- function rm(uint index) public {
- delete map[index];
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function(
- "set_string")
- .arguments(
- &[
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(786868768768678687686877u128)
- },
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- ], )
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("add_int")
- .arguments(&[
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(786868768768678687686877u128),
- },
- BorshToken::Int {
- width: 64,
- value: BigInt::from(102u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("get")
- .arguments(&[BorshToken::Uint {
- width: 256,
- value: BigInt::from(786868768768678687686877u128),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Tuple(vec![
- BorshToken::String(String::from("This is a string which should be a little longer than 32 bytes so we the the abi encoder")),
- BorshToken::Array(vec![
- BorshToken::Int {
- width: 64,
- value: BigInt::from(102u8)
- },
- ]),
- ])
- );
- }
- #[test]
- fn mapping_in_dynamic_array() {
- let mut vm = build_solidity(
- r#"
- contract foo {
- mapping (uint64 => uint64)[] public map;
- int64 public number;
- function set(uint64 array_no, uint64 index, uint64 val) public {
- map[array_no][index] = val;
- }
- function rm(uint64 array_no, uint64 index) public {
- delete map[array_no][index];
- }
- function push() public {
- map.push();
- }
- function pop() public {
- map.pop();
- }
- function setNumber(int64 x) public {
- number = x;
- }
- function length() public returns (uint64) {
- return map.length;
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("setNumber")
- .arguments(&[BorshToken::Int {
- width: 64,
- value: BigInt::from(2147483647),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("push")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("push")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- for array_no in 0..2 {
- for i in 0..10 {
- vm.function("set")
- .arguments(&[
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(array_no),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i + array_no * 500),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(300331 + i),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- }
- }
- for array_no in 0..2 {
- for i in 0..10 {
- let returns = vm
- .function("map")
- .arguments(&[
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(array_no),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i + array_no * 500),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(300331 + i)
- },
- );
- }
- }
- let returns = vm
- .function("map")
- .arguments(&[
- BorshToken::Uint {
- width: 256,
- value: BigInt::zero(),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(101u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero()
- }
- );
- vm.function("rm")
- .arguments(&[
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero(),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(104u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- for i in 0..10 {
- let returns = vm
- .function("map")
- .arguments(&[
- BorshToken::Uint {
- width: 256,
- value: BigInt::zero(),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- if 102 + i != 104 {
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(300331 + i)
- },
- );
- } else {
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero()
- }
- );
- }
- }
- let returns = vm
- .function("length")
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(2u8)
- }
- );
- vm.function("pop")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("length")
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::one()
- }
- );
- vm.function("pop")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("length")
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero()
- }
- );
- let returns = vm
- .function("number")
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Int {
- width: 64,
- value: BigInt::from(2147483647u64)
- }
- );
- }
- #[test]
- fn mapping_in_struct_in_dynamic_array() {
- let mut vm = build_solidity(
- r#"
- contract foo {
- struct A {
- mapping(uint256 => uint256) a;
- }
- A[] private map;
- int64 public number;
- function set(uint64 array_no, uint64 index, uint64 val) public {
- map[array_no].a[index] = val;
- }
- function get(uint64 array_no, uint64 index) public returns (uint256) {
- return map[array_no].a[index];
- }
- function rm(uint64 array_no, uint64 index) public {
- delete map[array_no].a[index];
- }
- function push() public {
- map.push();
- }
- function pop() public {
- map.pop();
- }
- function setNumber(int64 x) public {
- number = x;
- }
- }"#,
- );
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("setNumber")
- .arguments(&[BorshToken::Int {
- width: 64,
- value: BigInt::from(2147483647),
- }])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("push")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("push")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- for array_no in 0..2 {
- for i in 0..10 {
- vm.function("set")
- .arguments(&[
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(array_no),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i + array_no * 500),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(300331 + i),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- }
- }
- for array_no in 0..2 {
- for i in 0..10 {
- let returns = vm
- .function("get")
- .arguments(&[
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(array_no),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i + array_no * 500),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(300331 + i)
- },
- );
- }
- }
- let returns = vm
- .function("get")
- .arguments(&[
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero(),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(101u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 256,
- value: BigInt::zero(),
- },
- );
- vm.function("rm")
- .arguments(&[
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero(),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(104u8),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- for i in 0..10 {
- let returns = vm
- .function("get")
- .arguments(&[
- BorshToken::Uint {
- width: 64,
- value: BigInt::zero(),
- },
- BorshToken::Uint {
- width: 64,
- value: BigInt::from(102 + i),
- },
- ])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- if 102 + i != 104 {
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(300331 + i)
- }
- );
- } else {
- assert_eq!(
- returns,
- BorshToken::Uint {
- width: 256,
- value: BigInt::zero()
- }
- );
- }
- }
- vm.function("pop")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- vm.function("pop")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("number")
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Int {
- width: 64,
- value: BigInt::from(2147483647u64),
- }
- );
- }
- #[test]
- fn mapping_delete() {
- let mut vm = build_solidity(
- r#"
- contract DeleteTest {
- struct data_struct {
- address addr1;
- address addr2;
- }
- mapping(uint => data_struct) example;
- function addData(address sender) public {
- data_struct dt = data_struct({addr1: address(this), addr2: sender});
- uint id = 1;
- example[id] = dt;
- }
- function deltest() external {
- uint id = 1;
- delete example[id];
- }
- function get() public view returns (data_struct calldata) {
- uint id = 1;
- return example[id];
- }
- }
- "#,
- );
- let sender = account_new();
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let _ = vm
- .function("addData")
- .arguments(&[BorshToken::Address(sender)])
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let _ = vm
- .function("deltest")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let returns = vm
- .function("get")
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- returns,
- BorshToken::Tuple(vec![
- BorshToken::Address([
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0
- ]),
- BorshToken::Address([
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0
- ])
- ]),
- );
- }
- #[test]
- fn mapping_within_struct() {
- let mut vm = build_solidity(
- r#"
- contract CrowdFunding {
- struct Funder {
- address addr;
- uint amount;
- }
- struct Campaign {
- mapping(uint => Funder)[2] arr_mp;
- mapping (uint => Funder) funders;
- }
- uint numCampaigns;
- mapping (uint => Campaign) campaigns;
- function newCampaign(address sender) public returns (uint campaignID) {
- campaignID = numCampaigns++;
- Campaign storage _campaign = campaigns[campaignID];
- _campaign.funders[0] = Funder(sender, 100);
- _campaign.arr_mp[1][0] = Funder(sender, 105);
- }
- function getAmt() public view returns (uint) {
- Campaign storage _campaign = campaigns[numCampaigns - 1];
- return _campaign.funders[0].amount;
- }
- function getArrAmt() public view returns (uint) {
- Campaign storage _campaign = campaigns[numCampaigns - 1];
- return _campaign.arr_mp[1][0].amount;
- }
- }
- "#,
- );
- let sender = account_new();
- let data_account = vm.initialize_data_account();
- vm.function("new")
- .accounts(vec![("dataAccount", data_account)])
- .call();
- let ret = vm
- .function("newCampaign")
- .arguments(&[BorshToken::Address(sender)])
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- ret,
- BorshToken::Uint {
- width: 256,
- value: BigInt::zero(),
- }
- );
- let ret = vm
- .function("getAmt")
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- ret,
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(100u8),
- }
- );
- let ret = vm
- .function("getArrAmt")
- .accounts(vec![("dataAccount", data_account)])
- .call()
- .unwrap();
- assert_eq!(
- ret,
- BorshToken::Uint {
- width: 256,
- value: BigInt::from(105u8),
- }
- );
- }
|