diff --git a/bridges/snowbridge/pallets/system/src/lib.rs b/bridges/snowbridge/pallets/system/src/lib.rs index 1e8a788b7a5a..abe2897924ff 100644 --- a/bridges/snowbridge/pallets/system/src/lib.rs +++ b/bridges/snowbridge/pallets/system/src/lib.rs @@ -249,6 +249,7 @@ pub mod pallet { InvalidTokenTransferFees, InvalidPricingParameters, InvalidUpgradeParameters, + InvalidMetadata, } /// The set of registered agents @@ -624,6 +625,10 @@ pub mod pallet { metadata: AssetMetadata, ) -> DispatchResultWithPostInfo { ensure_root(origin)?; + ensure!( + metadata.decimals > 0 && metadata.name.len() > 0 && metadata.symbol.len() > 0, + Error::::InvalidMetadata + ); let location: Location = (*location).try_into().map_err(|_| Error::::UnsupportedLocationVersion)?; diff --git a/bridges/snowbridge/pallets/system/src/mock.rs b/bridges/snowbridge/pallets/system/src/mock.rs index 47b089866a53..3fd38ab4ede6 100644 --- a/bridges/snowbridge/pallets/system/src/mock.rs +++ b/bridges/snowbridge/pallets/system/src/mock.rs @@ -5,14 +5,14 @@ use frame_support::{ derive_impl, parameter_types, traits::{tokens::fungible::Mutate, ConstU128, ConstU8}, weights::IdentityFee, - PalletId, + BoundedVec, PalletId, }; use sp_core::H256; use xcm_executor::traits::ConvertLocation; use snowbridge_core::{ gwei, meth, outbound::ConstantGasMeter, sibling_sovereign_account, AgentId, AllowSiblingsOnly, - ParaId, PricingParameters, Rewards, + AssetMetadata, ParaId, PricingParameters, Rewards, }; use sp_runtime::{ traits::{AccountIdConversion, BlakeTwo256, IdentityLookup, Keccak256}, @@ -253,3 +253,11 @@ pub fn make_agent_id(location: Location) -> AgentId { ::AgentIdOf::convert_location(&location) .expect("convert location") } + +pub fn mock_asset_meta() -> AssetMetadata { + AssetMetadata { + name: BoundedVec::try_from("SDOT".as_bytes().to_vec()).unwrap(), + symbol: BoundedVec::try_from("SDOT".as_bytes().to_vec()).unwrap(), + decimals: 10, + } +} diff --git a/bridges/snowbridge/pallets/system/src/tests.rs b/bridges/snowbridge/pallets/system/src/tests.rs index d0286e04abdf..8e11ecc0075d 100644 --- a/bridges/snowbridge/pallets/system/src/tests.rs +++ b/bridges/snowbridge/pallets/system/src/tests.rs @@ -709,7 +709,7 @@ fn register_all_tokens_succeeds() { assert_ok!(EthereumSystem::register_token( origin, Box::new(versioned_location), - Default::default() + mock_asset_meta() )); assert_eq!(NativeToForeignId::::get(tc.reanchored.clone()), Some(tc.foreign)); @@ -739,8 +739,30 @@ fn register_ethereum_native_token_fails() { ); let versioned_location: Box = Box::new(location.clone().into()); assert_noop!( - EthereumSystem::register_token(origin, versioned_location, Default::default()), + EthereumSystem::register_token(origin, versioned_location, mock_asset_meta()), Error::::LocationConversionFailed ); }); } + +#[test] +fn register_token_with_invalid_meta_data_fails() { + new_test_ext(true).execute_with(|| { + let origin = RuntimeOrigin::root(); + let location = Location::new( + 2, + [ + GlobalConsensus(Ethereum { chain_id: 11155111 }), + AccountKey20 { + network: None, + key: hex!("87d1f7fdfEe7f651FaBc8bFCB6E086C278b77A7d"), + }, + ], + ); + let versioned_location: Box = Box::new(location.clone().into()); + assert_noop!( + EthereumSystem::register_token(origin, versioned_location, AssetMetadata::default()), + Error::::InvalidMetadata + ); + }); +}