diff --git a/land_registry/src/interface.cairo b/land_registry/src/interface.cairo index ba342a5c..3b6d2320 100644 --- a/land_registry/src/interface.cairo +++ b/land_registry/src/interface.cairo @@ -17,7 +17,7 @@ struct LandApprovalDetails { timestamp: u64, } -#[derive(Drop, Copy, Clone, Serde, starknet::Store, PartialEq)] +#[derive(Debug, Drop, Copy, Clone, Serde, starknet::Store, PartialEq)] pub enum LandUse { Residential, Commercial, diff --git a/land_registry/src/land_register.cairo b/land_registry/src/land_register.cairo index 3c2cfe21..098d8734 100644 --- a/land_registry/src/land_register.cairo +++ b/land_registry/src/land_register.cairo @@ -6,20 +6,14 @@ pub mod LandRegistryContract { use core::array::SpanTrait; use starknet::storage::{Map, StorageMapWriteAccess}; + #[storage] struct Storage { lands: Map::, - owner_lands: Map::>, + owner_lands: Map::, land_count: u256, } - - //lands - - //What are we storing? - - //lands, owners? - #[event] #[derive(Drop, starknet::Event)] enum Event { @@ -76,6 +70,10 @@ pub mod LandRegistryContract { self.lands.write(land_id, new_land); self.land_count.write(land_id); + self.owner_lands.write(caller, land_id); + + //Write new land to a specific owner.. + self .emit( LandRegistered { @@ -106,3 +104,36 @@ pub mod LandRegistryContract { } } } + +// #[cfg(test)] +// mod tests { +// use starknet::{get_caller_address, get_block_timestamp, ContractAddress}; + +// // Import the interface and dispatcher to be able to interact with the contract. +// use super::{SimpleContract, IContractDispatcher, ISimpleContractDispatcherTrait}; + +// // Import the deploy syscall to be able to deploy the contract. +// use starknet::{SyscallResultTrait, syscalls::deploy_syscall}; +// use starknet::{get_contract_address, contract_address_const}; + +// // Use starknet test utils to fake the contract_address +// use starknet::testing::set_contract_address; + +// // Deploy the contract and return its dispatcher. +// fn deploy(initial_value: u32) -> ISimpleContractDispatcher { +// // Declare and deploy +// let (contract_address, _) = deploy_syscall( +// SimpleContract::TEST_CLASS_HASH.try_into().unwrap(), +// 0, +// array![initial_value.into()].span(), +// false +// ) +// .unwrap_syscall(); + +// // Return the dispatcher. +// // The dispatcher allows to interact with the contract based on its interface. +// ISimpleContractDispatcher { contract_address } +// } + + +// } diff --git a/land_registry/src/lib.cairo b/land_registry/src/lib.cairo index 0527250e..1e71d9ec 100644 --- a/land_registry/src/lib.cairo +++ b/land_registry/src/lib.cairo @@ -1,3 +1,4 @@ pub mod interface; pub mod land_register; pub mod utils; +pub mod tests; diff --git a/land_registry/src/tests/test_land_register.cairo b/land_registry/src/tests/test_land_register.cairo index 05e52e1d..a1dea386 100644 --- a/land_registry/src/tests/test_land_register.cairo +++ b/land_registry/src/tests/test_land_register.cairo @@ -6,5 +6,4 @@ use starknet::ContractAddress; // TESTS // ************************************************************************* -//#[test]