8.9.1 coverage report
Legend:
Status for Story ID | Title | Story Overview |
---|---|---|
Obtain constitution hash for verification (HOLDER) → | As an Ada holder, I want to obtain the hash of the off-chain text of a Constitution, so that I can compare it against the hash registered on-chain to verify its authenticity. | |
Generate hash of the off-chain constitution (HOLDER) → | As an Ada holder, I want to generate the hash of the off-chain text for a proposed Constitution, so that the hash can be utilized in a governance action. | |
Generate Committee member cold key pair (CCM) → | As a potential Constitutional Committee member, I want to generate COLD key pair, so that I can be proposed for the Committee in a Governance action. | |
Generate committee member hot key pair (CCM) → | As potential Constitutional Committee member, I want to generate HOT key pair, so that I can authorise the Hot key to sign votes on behalf of the Cold key. | |
Authorization certificate (CCM) → | As a Constitutional Committee member, I want to issue a authorization certificate from my cold key to a hot key, so that I can sign my votes using the hot key and keep the cold key in cold storage and can authorise a new hot key in case the original one is compromised. | |
Generate committee member key hash (CCM) → | As a potential Constitutional Committee member, I want to generate the key hashes for my cold and hot keys, so that they can be used by third parties to propose me as a new Constitutional Committee member and for identification purposes once I’ve been elected as Constitutional Committee member. | |
Committee member resignation certificate (CCM) → | As a Constitutional Committee member, I want to be able to generate a resignation certificate, so that I can submit it to the chain on a transaction to signal to the Ada holders that I’m resigning from my duties as CC member. | |
Generate DRep keys (HOLDER) → | As an Ada holder, I want to generate Ed25519 keys, so that I can register as a DRep. | |
Generate DRep ID (DRep) → | As a DRep, I want to generate a DRep Id, so that Ada holder can use it to delegate their votes to me and my voting record can be tracked. | |
DRep Registration Certificate Generation (DRep) → | As a DRep, I want to generate a DRep registration certificate, so that I can submit it on a transaction and the Ada holders can delegate their votes to me. | |
DRep Retirement Certificate Generation (DRep) → | As a DRep, I want to generate a DRep retirement (unregistration) certificate, so that I can submit it on a transaction and can get my DRep deposit back. | |
DRep Metadata Hash Generation (DRep) → | As a DRep, I want to generate the hash of my DRep metadata, so that I can supply it when registering as DRep. | |
Create Update Constitution Governance Action (HOLDER) → | As an Ada holder, I want to create a governance action that updates the constitution, so that it can be submitted to the chain and be voted by the governance bodies. | |
Create Update Constitutional Committee Governance Action (HOLDER) → | As an Ada holder, I want to create a governance action that updates the Constitutional Committee, so that it can be submitted to the chain and be voted by the governance bodies. | |
Create Treasury Withdrawal Governance Action (HOLDER) → | As an Ada holder, I want to create a governance action to withdraw funds from the treasury, so that it can be submitted to the chain and be voted by the governance bodies. Command: cardano-cli conway governance action create-treasury-withdrawal. | |
Create info governance action (HOLDER) → | As an Ada holder, I want to create an info governance action, so that it can be submitted to the chain and be voted by the governance bodies. Command: cardano-cli conway governance action create-info. | |
Create update protocol parameters governance action (HOLDER) → | As an Ada holder, I want to create a governance action to update protocol parameters, so that it can be submitted to the chain and be voted by the governance bodies. Command: cardano-cli conway governance action create-protocol-parameters-update. | |
Create no-confidence governance action (HOLDER) → | As an Ada holder, I want to create a no-confidence governance action, so that it can be submitted to the chain and be voted by the governance bodies. Command: cardano-cli conway governance action create-no-confidence. | |
Create Hard-fork initiation governance action (HOLDER) → | As an Ada holder, I want to create a governance action to initiate a hardfork, so that it can be submitted to the chain and be voted by the governance bodies. Command: cardano-cli conway governance action create-hf-init. | |
View governance action file (HOLDER) → | As an Ada holder, I want to inspect the contents of a governance action file, so that I can verify it is correct before submitting it in a transaction. Command: cardano-cli conway governance action view. | |
Create a governance action vote (DRep/SPO/CCM) → | As a DRep, SPO or CC member, I want to create a vote for a governance action, so that I can include it in a transaction and submit it to the chain. Command: cardano-cli conway governance vote create. | |
View vote file (DRep/SPO/CCM) → | As a DRep, SPO or CC member, I want to inspect the contents of a vote file, so that I can verify it is correct before submitting it in a transaction. Command: cardano-cli conway governance vote view. | |
Build a transaction with to submit proposal (HOLDER) → | As an Ada holder, I want to build a transaction that includes a proposal (containing a governance action), so that I can later sign and submit to the chain. Command: transaction build. | |
Build transaction for proposal vote (DRep, SPO, CCM) → | As a DRep, SPO or CC member, I want to build a transaction that includes my vote on a particular governance action, so that I can later sign and submit to the chain. Command: transaction build. | |
Build RAW transaction for proposal vote (HOLDER) → | As an Ada holder, I want to build a transaction that includes a proposal (containing a governance action), so that I can later sign and submit to the chain. Command: transaction build-raw. | |
Build RAW transaction for proposal vote (DRep/SPO/CCM) → | As a DRep, SPO or CC member, I want to build a transaction that includes my vote on a particular governance action, so that I can later sign and submit to the chain. Command: transaction build-raw. | |
Create stake registration certificate (HOLDER) → | As an Ada holder, I want to create a conway cddl-compliant stake registration certificate. | |
Create stake deregistration certificate (HOLDER) → | As an Ada holder, I want to create a conway cddl-compliant stake deregistration certificate to get my deposit back. | |
Delegate vote to DRep (HOLDER) → | As an Ada holder, I want to delegate my votes to a DRep (registered or default), so that my stake is counted when the DRep votes. | |
Delegate stake to SPO and votes to DRep with a single certificate (HOLDER) → | As an Ada holder, I want to delegate my stake to a stake pool AND my votes to a DRep (registered or default) with a single certificate. | |
Query governance state (ANY) → | As any persona, I want to query the nodes for the currentGovernance state, so that I can inform my decisions. | |
Query committee state (CCM) → | As a CC member, I want to query the Constitutional Committee state, so that I can find my expiration term and whether my hot key authorization certificate has been recorded on chain. | |
Query DRep state (HOLDER) → | As an Ada holder, I want to query the DRep state, so that I can find detailed information about registered DReps. | |
Query DRep stake distribution (HOLDER) → | As an Ada holder and DRep, I want to query the DRep stake distribution, so that I can find the weight (of the votes) of each DRep. | |
Expand query stake-address-info to show deposits and vote delegation (HOLDER) → | As an Ada holder, I want to query my stake address information, so that I can learn to which pool and DRep I’m delegating to and the value in lovelace of my deposits for delegating and for submitting governance actions. | |
Query constitution. → | As any persona, I want to query the on-chain constitution, so that I can know the url where it is stored and the document hash so that I can verify authenticity. | |
Register script based DReps. → | ||
Unregister script based DReps. → | ||
Script based CC GA. --add --remove. → | ||
Script based CC GA. --add --remove. → |
Status for Story ID | Title | Story Overview |
---|---|---|
Constitution → | As a Stakeholder, I want the ledger to maintain a record of the hash value of the current constitution together with a URL hosting the off-chain document, so that I can verify the authenticity of the off-chain document. | |
Hash value of the off-chain Constitution is recorded on-chain → | As an Ada holder, I want the ledger state to record the hash of the current constitution, so that I can verify the authenticity of the off-chain document. | |
Node records Committee member key hashes, terms and status → | As an Ada holder, I want the key hash of active and expired Committee Members and their terms to be registered on-chain, so that the system can count their votes. | |
Authorization Certificate → | As a Committee Member, I want to submit a Cold to Hot key Authorization certificate, so that I can sign my votes using the hot key and keep my cold keys safely in cold storage. | |
Record cold credentials and authorization certificates on chain → | As a committee member, I want node’s ledger state to accurately maintain the record of key-hashes, terms, and cold to hot key authorization maps for active and expired members, so that only votes from active Committee members are considered. | |
Replacing the constitutional committee via a governance action → | As an Ada holder, I want to be able to submit a governance action to replace all or part of the current constitutional committee, so that committee members that have lost confidence of Ada holders can be removed from their duties. | |
Size of the constitutional committee → | As an Ada holder, I want the size of the constitutional committee to be adjustable (a protocol parameter), so that I can propose a different size via a governance action. | |
Committee voting threshold (quorum) can be modified → | As an Ada holder, I want that the committee threshold (the fraction of committee required to ratify a gov action) is not fixed, so that I can propose a different threshold via a governance action. | |
Electing an empty committee → | As an Ada holder, I want to be able to elect an empty committee if the community wishes to abolish the constitutional committee entirely, so that governance actions don’t need the votes of a constitutional committee to be ratified. | |
Constitutional committee members have a limited term → | As an Ada holder, I want each committee member to have an individual term, so that the system can have a rotation scheme. | |
Tracking committee member expirations → | As an Ada holder, I want the system to keep track of the expiration epoch of each committee member, so that the information is publicly available in the ledger and can be consumed by anyone interested. | |
Automatically expire committee members that have completed their terms → | As an Ada holder, I want the system to automatically expire committee members that have reached their term, so that only active committee members can vote. | |
Resign as committee member → | As a committee member, I want to be able to resign my responsibilities, so that I can stop my responsibilities with the Cardano Community while minimizing the effects on the system. | |
State of no-confidence → | As an Ada holder, I want to submit a governance action to depose the current constitutional committee and put the system in a no-confidence-state, so that the community must elect a new constitutional committee. | |
Automatically enter a state of no-confidence → | As an Ada holder, I want the system to automatically enter a state of no-confidence when the number of non-expired committee members falls below the minimal size of the committee, so that only update-committee governance actions can be ratified. | |
Proposal policy → | As an Ada holder, I want a supplementary script to the constitution, so that some proposal types are automatically restricted. | |
Delegate representatives → | As an Ada holder, I want stake credentials to delegate voting rights to a registered delegate representative (DRep), so that I can participate in the governance of the system. | |
Delegate to always abstain → | As an Ada holder or an exchange, I want to delegate my stake to the predefined option ‘Abstain’, so that my stake is marked as not participating in governance. | |
Delegate to no-confidence → | As an Ada holder, I want to delegate my stake to the predefined DRep ‘No Confidence’, so that my stake is counted as a ‘Yes’ vote on every ‘No Confidence’ action and a ‘No’ vote on every other action. | |
Inactive DReps → | As an Ada holder, I want DReps to be considered inactive if they don’t vote for drepActivity-many epochs, so that their delegated stake does not count towards the active voting stake, this to avoid leaving the system in a state where no governance action can pass. | |
DRep credentials → | As a DRep, I want to be identified by a credential (A verification key (Ed2559) or a Native or Plutus Script), so that I can register and vote on governance actions. | |
DRep registration certificate → | As a DRep, I want to generate a registration certificate, so that the system recognizes my credentials and counts my votes on governance actions. | |
Vote delegation certificate → | As an Ada holder, I want to generate a vote delegation certificate, so that I can delegate my voting rights. | |
DRep retirement certificate → | As a DRep, I want to generate a retirement certificate, so that the system and Ada holders (delegators) know that I’m no longer voting on governance actions and they should redelegate. | |
DRep retirement certificate is applied immediately after being accepted on-chain → | As a DRep, I want my retirement certificate to be applied immediately upon acceptance on-chain, so that the DRep deposit is returned in the same transaction, ensuring no waiting time. | |
per-DRep stake distribution → | As an Ada Holder, I want the system to calculate the stake distribution per DRep, so that each DRep's vote is weighted according to the actual stake delegated to them. This per-DRep stake distribution should use the stake snapshot from the last epoch boundary. | |
Bootstrapping phase → | ||
Block rewards withdrawals for stake credentials that are not delegating to a DRep → | As a Stakeholder I want that when bootstrapping phase ends, the system blocks rewards withdrawals for stake credentials that are not delegating to a DRep. | |
Types of governance actions → | As a Stakeholder I want the governance system to allow 7 different types of governance actions:
|
|
Governance action initiation → | As a Stakeholder, I want any stakeholder to be able to submit a governance action without restrictions, beyond those necessary for a transaction of this type to be considered valid. | |
Governance action initiation → | As a Stakeholder, I want Governance Actors to be required to provide a deposit in lovelace so that I can prevent the network from being spammed with meaningless governance actions. This deposit should be returned once the action is either ratified or expired. | |
Contents of governance actions → | As a Governance Actor, I want every governance action to contain the following elements:
|
|
New committee/threshold GA additional data → | As a Governance actor creating a New Committee governance action, I want to specify the following additional data:
|
|
Update the constitution GA additional data → | As a Governance actor creating a Update to the constitution GA, I want to include an anchor to the Constitution and an optional script hash of the proposal policy. | |
Hardfork initiation GA additional data → | As a Governance actor creating a hardfork initiation governance action, I want to include the new (greater) major protocol version. | |
Protocol parameter changes GA additional data → | As a Governance actor creating a protocol parameter change GA, I want to include the parameter to change and their new values. | |
Treasury withdrawal GA additional data → | As a governance actor creating a treasury withdrawal GA, I want to include a map from stake credentials to a positive number of Lovelace. | |
Governance action maximum lifetime → | As a Stakeholder, I want governance actions submitted in a transaction and admitted to the chain to remain active for up to govActionLifetime epochs so that these actions are checked for ratification at every epoch boundary within their govActionLifetime. If an action gathers enough 'yes' votes to meet the thresholds of the governing bodies, it is ratified; otherwise, if it fails to gather sufficient 'yes' votes during the active period, the proposal expires and is removed. | |
Enactment of ratified actions → | As a Stakeholder, I want ratified actions to be automatically enacted at the next epoch transition following their ratification. | |
Governance action deposit returns → | As a Governance Actor, I want governance action deposits to be returned immediately after ratification or expiration. | |
Deposits count towards voting power (stake) → | Governance action deposits are added to the deposit pot and count towards the stake of the reward address to which they will be returned, to ensure that the proposer can back their own action with their voting power. | |
Proposal policy → | As a Stakeholder, I want governance actions that attempt to change protocol parameters or involve treasury withdrawals to include the supplementary script from the constitution in the witness set, either directly or via reference inputs, whenever such a script exists. | |
Multiple protocol parameter updates → | As a Governance Actor I want a governance action to allow multiple protocol parameter changes at once. | |
Delay of ratification → | As a Stakeholder, I want the ratification of all other governance actions to be delayed until the first epoch following the enactment of a successful motion of no-confidence, the election of a new Constitutional Committee, a constitutional change, or a hard-fork. | |
Motion of no confidence, requirements for ratification → | As a Stakeholder I want that the ratification of a Motion of no confidence governance action requires:
|
|
New committee/threshold (normal state), requirements for ratification → | As a Stakeholder I want that the ratification of a New committee/threshold (normal state) governance action requires:
|
|
New committee/threshold (state of no-confidence), requirements for ratification → | As a Stakeholder I want that the ratification of a New committee/threshold (state of no-confidence) governance action requires:
|
|
Update to the Constitution or proposal policy, requirements for ratification → | As a Stakeholder I want that the ratification of a Update to the Constitution or proposal policy governance action requires:
|
|
Hard-fork initiation, requirements for ratification → | As a Stakeholder I want that the ratification of a Hard-fork initiation governance action requires:
|
|
Protocol parameter changes, network group → | As a Stakeholder I want that the ratification of a network group protocol parameter change requires:
|
|
Protocol parameter changes, economic group → | As a Stakeholder I want that the ratification of a economic group protocol parameter change requires:
|
|
Protocol parameter changes, technical group → | As a Stakeholder I want that the ratification of a technical group protocol parameter change requires:
|
|
Protocol parameter changes, governance group → | As a Stakeholder I want that the ratification of a governance group protocol parameter change requires:
|
|
Treasury withdrawal, requirements for ratification → | As a Stakeholder I want that the ratification of a Treasury withdrawal governance action requires:
|
|
The network group protocol parameters → | As a Stakeholder I want the network group consist of:
|
|
The economic group protocol parameters → | As a Stakeholder I want that the economic group consist of:
|
|
The technical group protocol parameters → | As a Stakeholder I want that the technical group consist of:
|
|
The governance group protocol parameters → | As a Stakeholder I want that the governance group consist of:
|
|
Thresholds for Info is set to 100% → | As a Stakeholder I want the two thresholds for the Info action be set to 100% since setting it any lower would result in not being able to poll above the threshold. | |
Preventing accidental clash of actions of the same type → | As a Stakeholder I want all governance actions, except for Treasury withdrawals and Infos, to include the governance action ID of the most recently enacted action of the same type so that accidental clashes between actions can be prevented. | |
Governance action enactment prioritization → | As a Stakeholder I want actions that have been ratified in the current epoch to be prioritized for enactment in the following order:
|
|
Governance action order of enactment → | As a Stakeholder I want governance actions to be enacted in the order of their acceptance to the chain. | |
Governance actions automatic enactment → | As a Stakeholder I want ratified actions to be automatically enacted at the next epoch boundary. | |
No duplicate committee members → | As a Stakeholder I want each pair of credentials in a committee to be unique, ensuring no duplicate committee members. | |
Governance action ID → | As a Stakeholder I want the transaction ID and index of the transaction that submits the governance action to the chain to serve as the governance action ID so that this ID shall would be used for casting votes. | |
Vote transactions contents → | As a Stakeholder I want each vote transaction to consist of the following elements:
|
|
SPO and DREP votes are proportional to the stake delegated to them → | For SPOs and DReps, the number of votes cast ('Yes', 'No', or 'Abstain') shall be proportional to the amount of Lovelace delegated to them at the time the action is checked for ratification. | |
CC votes → | As a Stakeholder I want each current committee member to have one vote. | |
Active voting stake → | As a Stakeholder I want the active voting stake to be the total registered stake minus the abstain votes stake (both credential DReps and AlwaysAbstain). | |
Unregistered stake behaves like Abstain vote → | As a Stakeholder I want unregistered stake to be treated as an abstain vote so that it should not count towards the active voting stake. | |
Registered stake that did not vote behaves like a 'No' vote → | As a Stakeholder I want any registered stake that did not submit a vote, whether through its DRep or SPO, to be counted as a 'No' vote. | |
New Plutus script purpose for scripts → | As a Stakeholder I want a new voting purpose for Plutus scripts. | |
Any new vote overrides any older vote for the same credential and role → | As a Stakeholder I want new votes on a governance action to override any previous votes for the same credential and role so that individuals could change their minds. | |
Voting ends when an action is ratified and transactions containing further votes are invalid → | As a Stakeholder I want the voting period to terminate immediately after an action is ratified or expires. | |
Governance state tracking governance action progress → | As a Stakeholder I want the governance state section of the ledger to track the progress of governance actions to include: capturing votes, tracking the expiration epoch, and other relevant information until the actions are either ratified or expired. | |
Remove MIR certificates → | As a Stakeholder I want MIR certificates to be removed so that the only way to withdraw funds from the treasury is through a ratified Treasury Withdrawal governance action. | |
Remove genesis certificates → | As a Stakeholder I want genesis certificates to be removed. In Conway era these are no longer useful or required. | |
Changes to the existing ledger rules → | As a Stakeholder I want the ledger to adjust its rules to accommodate for the governance features, i.e. Delegations, Certificates, Proposals, Votes, Ratification, Enactment. | |
Changes to the local state-query protocol → | As a Stakeholder I want the ledger to adjust the local state query protocol to accommodate for new queries that provide insights about governance, at least:
|
|
Ratification of Security related parameters → | The security relevant protocol parameters require the approval of the three governing bodies.
|
|
Auditor review of current network parameters → | As an Auditor, I want to audit the current state of the network parameters, so that I can ensure they align with the governance decisions. | |
Auditor review of current technical parameters → | As an Auditor, I want to audit the current technical parameters, including consenus and cost models so that I can ensure their compliance with the network parameters specified. | |
Auditor review of current economic parameters → | As an Auditor, I want to audit the current economic parameters, including parameters affecting transaction fees, taxes, and staking rewards so that I can assess their impact on the network's economy. | |
Auditor review of current governance parameters and voting thresholds → | As an Auditor, I want to audit the current governance parameters and voting thresholds for governance actions to fail or ratify so that I can verify their appropriateness and adherence to governance rules, adherence to the constitution, and enforcement of voting thresholds. | |
Auditor review of current state of the treasury → | As an Auditor, I want to audit the current state of the treasury, including the total amount of Ada, so that I can assess the current balance and the system's financial health. | |
Auditor needs access to historical proposals affecting network parameters → | As an Auditor, I want to access and review the history of proposals related to network parameters, including their outcomes, so that I can track governance effectiveness over time. | |
Auditor needs access to historical proposals affecting technical parameters → | As an Auditor, I want to access and review the history of proposals related to technical parameters, including both ratified and failed proposals, so that I can understand technical evolution and parameter change impact. | |
Auditor needs access to historical proposals affecting economic parameters → | As an Auditor, I want to access and review the history of proposals related to economic parameters, focusing on their ratification status, so that I can evaluate economic policy changes. | |
Auditor needs access to the historical record of all governance proposals and voting thresholds → | As an Auditor, I want to access history changes to governance parameters, the proposals, and the voting thresholds, so that I can audit the changes made over time and verify compliance with governance rules, and evaluate the impact of these changes on governance actions' outcomes, with the primary purpose to verify voting thresholds were enforced. | |
Auditor needs access to the history of treasury withdrawals → | As an Auditor, I want to audit the history of treasury withdrawals, including amounts, dates, and recipient wallet addresses, so that I can ensure transparency and accountability. |