use of com.radixdlt.application.tokens.construction.StakeTokensConstructorV3 in project radixdlt by radixdlt.
the class NextViewV2Test method setup.
@Before
public void setup() throws Exception {
var cmAtomOS = new CMAtomOS();
cmAtomOS.load(new SystemConstraintScrypt());
scrypts.forEach(cmAtomOS::load);
cmAtomOS.load(new StakingConstraintScryptV4(Amount.ofTokens(10).toSubunits()));
cmAtomOS.load(new TokensConstraintScryptV3(Set.of(), Pattern.compile("[a-z0-9]+")));
cmAtomOS.load(new ValidatorConstraintScryptV2());
cmAtomOS.load(new ValidatorRegisterConstraintScrypt());
cmAtomOS.load(new ValidatorUpdateRakeConstraintScrypt(2));
cmAtomOS.load(new ValidatorUpdateOwnerConstraintScrypt());
var cm = new ConstraintMachine(cmAtomOS.getProcedures(), cmAtomOS.buildSubstateDeserialization(), cmAtomOS.buildVirtualSubstateDeserialization());
var parser = new REParser(cmAtomOS.buildSubstateDeserialization());
var serialization = cmAtomOS.buildSubstateSerialization();
this.store = new InMemoryEngineStore<>();
this.sut = new RadixEngine<>(parser, serialization, REConstructor.newBuilder().put(NextEpoch.class, new NextEpochConstructorV3(Amount.ofTokens(10).toSubunits(), 9800, 1, 10)).put(CreateSystem.class, new CreateSystemConstructorV2()).put(CreateMutableToken.class, new CreateMutableTokenConstructor(SystemConstraintScrypt.MAX_SYMBOL_LENGTH)).put(MintToken.class, new MintTokenConstructor()).put(StakeTokens.class, new StakeTokensConstructorV3(Amount.ofTokens(10).toSubunits())).put(NextRound.class, nextViewConstructor).put(RegisterValidator.class, new RegisterValidatorConstructor()).build(), cm, store);
this.key = ECKeyPair.generateNew();
var accountAddr = REAddr.ofPubKeyAccount(key.getPublicKey());
var txn = this.sut.construct(TxnConstructionRequest.create().action(new CreateSystem(0)).action(new CreateMutableToken(REAddr.ofNativeToken(), "xrd", "xrd", "", "", "", null)).action(new MintToken(REAddr.ofNativeToken(), accountAddr, Amount.ofTokens(10).toSubunits())).action(new StakeTokens(accountAddr, key.getPublicKey(), Amount.ofTokens(10).toSubunits())).action(new RegisterValidator(key.getPublicKey())).action(new NextEpoch(0))).buildWithoutSignature();
this.sut.execute(List.of(txn), null, PermissionLevel.SYSTEM);
}
use of com.radixdlt.application.tokens.construction.StakeTokensConstructorV3 in project radixdlt by radixdlt.
the class DelegationFlagTest method parameters.
@Parameterized.Parameters
public static Collection<Object[]> parameters() {
var startAmounts = List.of(10);
var stakeAmounts = List.of(10);
var scrypts = List.of(Pair.of(List.of(new RoundUpdateConstraintScrypt(10), new EpochUpdateConstraintScrypt(10, UInt256.NINE, 1, 1, 10), new TokensConstraintScryptV3(Set.of(), Pattern.compile("[a-z0-9]+")), new StakingConstraintScryptV4(Amount.ofTokens(10).toSubunits()), new ValidatorConstraintScryptV2(), new ValidatorUpdateOwnerConstraintScrypt()), new StakeTokensConstructorV3(Amount.ofTokens(10).toSubunits())));
var parameters = new ArrayList<Object[]>();
for (var scrypt : scrypts) {
for (var startAmount : startAmounts) {
for (var stakeAmount : stakeAmounts) {
var param = new Object[] { startAmount, stakeAmount, scrypt.getFirst(), scrypt.getSecond() };
parameters.add(param);
}
}
}
return parameters;
}
use of com.radixdlt.application.tokens.construction.StakeTokensConstructorV3 in project radixdlt by radixdlt.
the class StakeTokensTest method parameters.
@Parameterized.Parameters
public static Collection<Object[]> parameters() {
var startAmounts = List.of(10);
var stakeAmounts = List.of(10, 6);
var scrypts = List.of(Pair.of(List.of(new SystemConstraintScrypt(), new TokensConstraintScryptV3(Set.of(), Pattern.compile("[a-z0-9]+")), new StakingConstraintScryptV4(Amount.ofTokens(10).toSubunits()), new ValidatorConstraintScryptV2(), new ValidatorUpdateOwnerConstraintScrypt()), new StakeTokensConstructorV3(Amount.ofTokens(10).toSubunits())));
var parameters = new ArrayList<Object[]>();
for (var scrypt : scrypts) {
for (var startAmount : startAmounts) {
for (var stakeAmount : stakeAmounts) {
var param = new Object[] { startAmount, stakeAmount, scrypt.getFirst(), scrypt.getSecond() };
parameters.add(param);
}
}
}
return parameters;
}
Aggregations