November 14, 2022

Shardeum: полный гайд по тестированию проекта. Точно будет дроп!

Shardeum - это масштабируемый EVM (Ethereum Virtual Machine - виртуальная машина Эфира) совместимый блокчейн первого уровня, который обеспечивает низкую плату за газ, сохраняя при этом высокий уровень децентрализации и надежную безопасность, благодаря динамическому сегментированию.

Инвесторы: проект привлек более 18 миллионов долларов от Spartan Group, Struck Crypto, Big Brain Holdings и CoinGecko и др.

Награды: официальных заявлений насчет наград не было, но в экосистему и Airdrop заложено 5% от всех монет, то есть 25.40M $SHM.

Подготовка к тестированию Shardeum

Для начала нам необходимо добавить тестовую сеть Shardeum в Метамаске. Для этого открываем сайт Chainlist.org, нажимаем на переключатель, чтобы нам показывались тестовые сети, вводим в поиске Shardeum, находим Shardeum Liberty 1.5 (или Shardeum 1.6 - это неважно, главное - чтобы первая цифра была 1), подключаем кошелек, добавляем сеть и меняем сеть в расширении Метамаска на Shardeum.

Идем в кран тестовых монет, нажимаем на зеленую надпись Tweet Now, откроется заготовленный твит, вставляем вместо нулевого адреса адрес своего кошелька, делаем твит. Затем копируем ссылку на твит, вставляем в текстовое поле на сайте и кликаем на Request SHM.

После этих действий нам должны будут зачислить 100 монет SHM. Проверяем в кошельке.

Тестируем Swapped Finance

Swapped Finance - DEX в сети Shardeum.

Открываем приложение Swapped Finance, коннектим кошелек, делаем 5-10 обменов.

Переходим во вкладку Пул -> Добавить, добавляем ликвидность.

Переходим СЮДА, проходим квиз по Swapped Finance, клеймим за это NFT.
Ответы:

  • SHARDEUM
  • 0.3
  • 0.21675

Тестируем Shardeum Name Service

Shardeum Name Service - сервис Web3 имен в сети Shardeum.

Переходим в приложение, коннектим кошелек, вводим сверху желаемое имя, нажимаем Mint, подписываем в кошельке.

Тестируем Spriyo

Spriyo - NFT маркетплейс / сервис для работы с NFT в сети Shardeum.

Переходим на сайт, коннектим кошелек, справа сверху нажимаем Create, затем Single, вводим все данные и минтим свою собственную NFT в блокчейне Shardeum.

Минтим потенциально гемные Boss Baby NFT

Boss Baby NFT - коллекция, состоящая из 5555 случайно сгенерированных картинок боcсов младенцев.

Переходим на сайт, коннектим кошелек, минтим NFT, пока еще можно.

Развертываем смарт контракт в новой сети Shardeum Liberty 2.0

Я нашел в сети интересный гайд, в котором автор рассказал, как развернуть простенький контракт в новой сети Shardeum Liberty 2.0. Но в данном случае можно использовать любой смарт контракт, который есть в сети Ethereum, поэтому я решил вместо контракта, который предлагает автор, развернуть более интересный и более структурированный смарт контракт, созданный для проведения разного рода голосований.

Для начала нам нужно добавить сеть Shardeum Liberty 2.0 в наш Метамаск с помощью сайта Chainlist.

Используем кран тестовых монет для Shardeum Liberty 2.0.

Или отправляем запрос в Дискорде в ветке #faucet-2.0

Открываем Remix (платформа для написания смарт контрактов на Solidity).

Создаем новый файл под названием Ballot.sol в папке contracts. Обратите внимание на то, что там уже есть файл _Ballot.sol, который содержит тот же самый код, что мы собираемся использовать. Но для уверенности в происходящем советую действовать по инструкции, а не использовать готовый файл с кодом.

Вставляем в Ballot.sol следующий код

// SPDX-License-Identifier: GPL-3.0
pragma solidity >=0.7.0 <0.9.0;
/// @title Voting with delegation.
contract Ballot {
    // This declares a new complex type which will
    // be used for variables later.
    // It will represent a single voter.
    struct Voter {
        uint weight; // weight is accumulated by delegation
        bool voted;  // if true, that person already voted
        address delegate; // person delegated to
        uint vote;   // index of the voted proposal
    }

    // This is a type for a single proposal.
    struct Proposal {
        bytes32 name;   // short name (up to 32 bytes)
        uint voteCount; // number of accumulated votes
    }

    address public chairperson;

    // This declares a state variable that
    // stores a `Voter` struct for each possible address.
    mapping(address => Voter) public voters;

    // A dynamically-sized array of `Proposal` structs.
    Proposal[] public proposals;

    /// Create a new ballot to choose one of `proposalNames`.
    constructor(bytes32[] memory proposalNames) {
        chairperson = msg.sender;
        voters[chairperson].weight = 1;

        // For each of the provided proposal names,
        // create a new proposal object and add it
        // to the end of the array.
        for (uint i = 0; i < proposalNames.length; i++) {
            // `Proposal({...})` creates a temporary
            // Proposal object and `proposals.push(...)`
            // appends it to the end of `proposals`.
            proposals.push(Proposal({
                name: proposalNames[i],
                voteCount: 0
            }));
        }
    }

    // Give `voter` the right to vote on this ballot.
    // May only be called by `chairperson`.
    function giveRightToVote(address voter) external {
        // If the first argument of `require` evaluates
        // to `false`, execution terminates and all
        // changes to the state and to Ether balances
        // are reverted.
        // This used to consume all gas in old EVM versions, but
        // not anymore.
        // It is often a good idea to use `require` to check if
        // functions are called correctly.
        // As a second argument, you can also provide an
        // explanation about what went wrong.
        require(
            msg.sender == chairperson,
            "Only chairperson can give right to vote."
        );
        require(
            !voters[voter].voted,
            "The voter already voted."
        );
        require(voters[voter].weight == 0);
        voters[voter].weight = 1;
    }

    /// Delegate your vote to the voter `to`.
    function delegate(address to) external {
        // assigns reference
        Voter storage sender = voters[msg.sender];
        require(sender.weight != 0, "You have no right to vote");
        require(!sender.voted, "You already voted.");

        require(to != msg.sender, "Self-delegation is disallowed.");

        // Forward the delegation as long as
        // `to` also delegated.
        // In general, such loops are very dangerous,
        // because if they run too long, they might
        // need more gas than is available in a block.
        // In this case, the delegation will not be executed,
        // but in other situations, such loops might
        // cause a contract to get "stuck" completely.
        while (voters[to].delegate != address(0)) {
            to = voters[to].delegate;

            // We found a loop in the delegation, not allowed.
            require(to != msg.sender, "Found loop in delegation.");
        }

        Voter storage delegate_ = voters[to];

        // Voters cannot delegate to accounts that cannot vote.
        require(delegate_.weight >= 1);

        // Since `sender` is a reference, this
        // modifies `voters[msg.sender]`.
        sender.voted = true;
        sender.delegate = to;

        if (delegate_.voted) {
            // If the delegate already voted,
            // directly add to the number of votes
            proposals[delegate_.vote].voteCount += sender.weight;
        } else {
            // If the delegate did not vote yet,
            // add to her weight.
            delegate_.weight += sender.weight;
        }
    }

    /// Give your vote (including votes delegated to you)
    /// to proposal `proposals[proposal].name`.
    function vote(uint proposal) external {
        Voter storage sender = voters[msg.sender];
        require(sender.weight != 0, "Has no right to vote");
        require(!sender.voted, "Already voted.");
        sender.voted = true;
        sender.vote = proposal;

        // If `proposal` is out of the range of the array,
        // this will throw automatically and revert all
        // changes.
        proposals[proposal].voteCount += sender.weight;
    }

    /// @dev Computes the winning proposal taking all
    /// previous votes into account.
    function winningProposal() public view
            returns (uint winningProposal_)
    {
        uint winningVoteCount = 0;
        for (uint p = 0; p < proposals.length; p++) {
            if (proposals[p].voteCount > winningVoteCount) {
                winningVoteCount = proposals[p].voteCount;
                winningProposal_ = p;
            }
        }
    }

    // Calls winningProposal() function to get the index
    // of the winner contained in the proposals array and then
    // returns the name of the winner
    function winnerName() external view
            returns (bytes32 winnerName_)
    {
        winnerName_ = proposals[winningProposal()].name;
    }
}

Нажимаем ctr + S (для мака cmd + S), чтобы скомпилировать код.

Теперь открываем слева нижнюю вкладку, в графе ENVIRONMENT выбираем Injected Provider - MetaMask. Проверяем, что в разделе CONTRACT(Compiled by Remix) выбрано Ballot.sol. Вписываем варианты для голосования в виде массива HEX-32 значений в графе возле кнопки Deploy:

["0x6c00000000000000011100000000000000000000000000000000000000000000","0x6c00222000000000000000000000000000000000000000000000000000000000","0x6c00000000000333000000000000000000000000000000000000000000000000"]

Затем нажимаем Deploy и подписываем в кошельке.

Если все прошло успешно, мы увидим внизу зеленую галочку и данные транзакции, в которой произошло создание смарт контракта.

Нажимаем на строчку возле зеленой галочки, копируем информацию из раздела transaction hash.

Идем в Shardeum Explorer, вставляем адрес транзакции и проверяем значения.

На этом тестирование блокчейна Shardeum закончено!

Спасибо за внимание!

Ссылка на TG канал: https://t.me/cryptonik_space