`underlying.transferFrom` в руководстве по составным документам выдает эту ошибку: `ProviderError: Ошибка: транзакция отменена без каски строки причины`

Я пытаюсь предоставить составной протокол в приложении, которое я создаю.
Также следуя составному документу и руководству здесь: Сообщение в блоге составного соединения
После локального разветвления основной сети и олицетворения адреса с большим USDT я теперь пытаюсь одолжить составной протокол.

В моем тесте эта строка underlying.transferFrom всегда терпит неудачу с этой ошибкой: ProviderError: Error: Transaction reverted without a reason string
Любые предположения о том, что может быть причиной.

Я спрашивал о сложном разногласии и не получил ответа.
Также провел много исследований, не смог найти подобную проблему... не знаю, что еще делать.
Ниже приведен пример моего кода

Среда разработки: Hardhat
ОС: Windows 10

      pragma solidity ^0.8.0;
import "hardhat/console.sol";
import "../interfaces/ICompound.sol";

contract CompoundController {
    mapping(address => mapping(address => UserInvestedTokenDetails))
        public UserInvestments;

    struct UserInvestedTokenDetails {
        uint256 tokenAmount;
        bool isExists;
    }

    function _setUserInvestments(
        address userAddress,
        address tokenAddress,
        uint256 tokenAmount
    ) internal {
        if (UserInvestments[userAddress][tokenAddress].isExists) {
            UserInvestments[userAddress][tokenAddress]
                .tokenAmount += tokenAmount;
        } else {
            UserInvestments[userAddress][
                tokenAddress
            ] = UserInvestedTokenDetails(tokenAmount, true);
        }
    }

    function supplyErc20ToCompound(
        address _erc20,
        address _cErc20,
        uint256 tokenAmount
    ) public returns (bool) {
        console.log("contract!");
        // Token being supplied to compound
        Erc20 underlying = Erc20(_erc20);
        // Token sent from compound in return
        CErc20 cToken = CErc20(_cErc20);
        require(
            underlying.transferFrom(msg.sender, address(this), tokenAmount),
            "compound: transferring tokens from user failed!"
        );

        underlying.approve(_cErc20, tokenAmount);
        require(cToken.mint(tokenAmount) == 0, "compound: mint failed!");
        _setUserInvestments(msg.sender, _erc20, tokenAmount);
        return true;
    }

}

Также тестовый файл по запросу:

      const { expect } = require("chai");
const { BigNumber } = require("ethers");
const { ethers } = require("hardhat");
const DAI = process.env.DAI;
const USDT = process.env.USDT;
//
const cDAI = process.env.DAI;
const cUSDT = process.env.CUSDT;

const USDT_WHALE = process.env.USDT_WHALE;

describe("CompoundController", function () {
  before(async () => {
    [deployer, user1, user2] = await ethers.getSigners();
    CompoundController = await ethers.getContractFactory("CompoundController");
    compoundController = await CompoundController.deploy();

    // FUND USERS ACCOUNT WITH PAYMENT OPTIONs TOKEN
    Usdt = await ethers.getContractAt("IERC20", USDT);
    Dai = await ethers.getContractAt("IERC20", DAI);
  });
  describe("sendErc20", function () {
    it("should supply tokens to compound", async () => {
      let depositAmount = BigNumber.from("100000000000000000000"); //  100
      await hre.network.provider.request({
        method: "hardhat_impersonateAccount",
        params: [USDT_WHALE],
      });
      const signer = await ethers.getSigner(USDT_WHALE);
      await Usdt.connect(signer).approve(
        compoundController.address,
        depositAmount
      );
      let tx = await compoundController
        .connect(signer)
        .supplyErc20ToCompound(USDT, cUSDT, depositAmount);
      console.log(tx);
    });
  });
});

2 ответа

Итак, после нескольких дней борьбы с этим я нашел эти указатели.

  • Контракт USDT почему-то не соответствует стандарту eip20. Он не возвращает логическое значение, поэтому мой интерфейс для всех контрактов erc20 не соответствовал их функции. Сразу же я протестировал DAI, который был совместим с eip20, и это сработало.
  • Также в какой-то момент при разветвлении основной сети в моей учетной записи подписывающего лица (учетной записи, с которой я тестировался) не было токена (достаточно USDT), который я пытался предоставить для соединения.

Я имею в виду, что проблема контракта USDT расстраивает, надеюсь, кто-то еще найдет это полезным.

Я думаю, что пользователь должен одобрить контрактный адрес для передачи от своего имени, прежде чем вы попытаетесь transferFrom.

Другие вопросы по тегам