-
Notifications
You must be signed in to change notification settings - Fork 14
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Polkadot v1.1.0 #489
Polkadot v1.1.0 #489
Conversation
Do we have a ticket for this, so i can link here as blocked? |
@prayagd they have to be redeployed but after the changes on this PR are finished. Sorry it pinged you since it is still a draft. |
cf8d3fc
to
2a877c2
Compare
bf86944
to
da67709
Compare
da67709
to
fda5880
Compare
0ca56f4
to
5ec2769
Compare
a9e4f25
to
34937d3
Compare
Thanks for explaining that part again 👍 Yes I fully agree that not having to patch all dependencies is the better approach, so let's stick to the runtimes from the
I would opt for including it in the same PR as the weights are only required due to the updated dependencies and we shouldn't roll out the runtime upgrade without regenerating them first. I would hope that this is not too much overhead. |
…fault weight" This reverts commit 79012a1.
I updated the weights by running the benchmarks again. Created a simple script for this that will run all the existing benchmarks on the weights folder, ignoring fails. @pendulum-chain/devs If you like this script we can keep it, I'll add it to the REAMDE. Also added a fix for the failing Only pallet
This is a bit surprising since also We can either choose to investigate further, or use EDIT: Should also add that the benchmark also fails in |
I briefly compared the runtime definitions of pendulum and amplitude but was not able to spot the difference that could make the benchmark fail on pendulum. @gianfra-t which one of the benchmark functions fails exactly? I'm happy to keep your shell script for the weight generation, thanks for creating it 👍 |
When you benchmark on So clearly the issue must be closer to the |
I'm not 100% sure but maybe it's because of the differing values for the thresholds (e.g. this) of the vault registry in the genesis configuration of pendulum vs amplitude in |
Nope, same error 🤔. |
@ebma I pushed a change to increase the amount of tokens issued before liquidating and this solves the fix. I suspect this line and subsequent transfer, but I have no idea why it worked on Amplitude. In any case I executed both again with the same parameter. Technically we should point to a new @pendulum-chain/devs let me know if I missed an open question or remark since this PR grew a bit too much already! |
Although we don't 100% know which caused the issue, the amount used was very low so the fix is fine with me. Let's point to the new Spacewalk |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me! Nothing else to add here 👍🏼
Co-authored-by: Marcel Ebert <mail@marcel-ebert.de>
I'll just merge it for you @gianfra-t. |
@pendulum-chain/product: This PR adds changes to the node client code that require a redeployment of the collator nodes to take effect.
Please ensure that the collator nodes are redeployed after this PR is merged.
Closes #481 .
Notable changes and decisions.
Convert<A,B>
, since it is not available anymore. (previous definition, cannot be found anymore on the same module) and it is no longer required (no compilation error on runtimes).1.1.0
branch, we can use commit46ba3689c2fe1011cce0d752cb479e0e522e2e76
which is when the feature was merged intodevelop
branch, at that time using 1.1.0.start_collator
anymore since it is all started instart_consensus
function. Example.start_full_node
is deprecated, the correct way to start the relay chain functions is now using the following. Note: The behavior is the same, since previouslystart_collator
which is also deprecated, would start anyway the relay chain functions.pallet-contracts
new types added. Decisions on values to take are Hash Lockup Deposit and max delegate dependencyFor
Environment
, only valid value is()
.UnsafeDebug
here. I believe it is fine to use them since as per comments on the pallet, should only be used for RPC. Same withUnsafeCollect
.pallet-xcm
's new typeMaxRemoteLockConsumers
. See changes here. I do not fully understand the implications of this value and I've chosen0
to maintain functionality. Related PR and changelog.Integration tests changes.
Now we differentiate between the
xcm-simulator
andxcm-emulator
. See the small wiki here. Previous macros now belong to the simulator, while from the description I infer that what we actually need for integration tests is the emulator. I also tested the simulator since it required less changes but I was gettingUnroutable
errors for every xcm message sent. Therefore, for these two reasons I decided to move to the emulator.Most of the code changes revolve around the new macro definitions and most importantly the genesis config of these test chains.
Asset-hub runtimes issue.
Initially it was attempted to get the runtimes from the new fellows repo. The issue is that it uses the
crates.io
version of the polkadot dependencies, which brought conflicts when using the unit tests, since all our dependencies are from thepolkadot-sdk
repo, branchrelease-polkadot-v1.1.0
. Although they are the same torelease-crates-io-v1.1.0
, the version scheme changes.The solution to this issue was to implement a patch with all packages specified to normalize for this branch (attempted in this commit). Previous macros for building the externalities are now replaced by the genesis config.
Alternatively, we can use the runtimes from the
polkadot-sdk
repository, although they seem to be fixed at version9.42
of the runtime, while maintaining compatibility with the dependencies. Since this is only used for unit testing I have implemented this second option to avoid the maintaining the patch. The alternative is also possible if we require so in the future.Testing Migrations
Related ticket. Only
pallet_contracts
seems to define a migration for this update. In this case, from10
to15
.Also, both
pallet_bounties
andparachain_staking
need to be bumped to the correct version (4
and7
respectively).According to this PR, the migration for
Bounties
must happen because the prefix was changed. Now, while running these migrations as defined on the companion update for Kusama/Polkadot at that time, we get that the new prefix is not empty (we get this error), hinting that the storage already lives on the new prefix.We can test the application of this migrations with the
try-runtime
tool. Command to run it and docs in our notion. The output of this should tell us if the migrations will be applied correctly or not.Bandersnatch_vfrs patch
Addition of this patch exception was required due to an error in compilation with
nightly-2024-04-18
, see run issue. Using a new nightly version solves the issue (nightly-2024-05-30
for instance), but the packagebandersnatch_vrfs
was not found. Solution found here.Open questions
validation_data
. If we still want to provide aparachain_inherent
aside from timestamp, we need to figure out how to create it.As far as I see from other chains and templates (bifrost, sdk template) it is okay to pass an empty closure since the pallet will take care of adding the inherents by default.