Migrate Ownable tests (#4657)
Co-authored-by: ernestognw <ernestognw@gmail.com>
This commit is contained in:
@ -1,18 +1,40 @@
|
||||
const { HardhatError } = require('hardhat/internal/core/errors');
|
||||
|
||||
// Modifies `artifacts.require(X)` so that instead of X it loads the XUpgradeable contract.
|
||||
function isExpectedError(e, suffix) {
|
||||
// HH700: Artifact not found - from https://hardhat.org/hardhat-runner/docs/errors#HH700
|
||||
return HardhatError.isHardhatError(e) && e.number === 700 && suffix !== '';
|
||||
}
|
||||
|
||||
// Modifies the artifact require functions so that instead of X it loads the XUpgradeable contract.
|
||||
// This allows us to run the same test suite on both the original and the transpiled and renamed Upgradeable contracts.
|
||||
extendEnvironment(hre => {
|
||||
const suffixes = ['UpgradeableWithInit', 'Upgradeable', ''];
|
||||
|
||||
extendEnvironment(env => {
|
||||
const artifactsRequire = env.artifacts.require;
|
||||
|
||||
env.artifacts.require = name => {
|
||||
for (const suffix of ['UpgradeableWithInit', 'Upgradeable', '']) {
|
||||
// Truffe (deprecated)
|
||||
const originalRequire = hre.artifacts.require;
|
||||
hre.artifacts.require = function (name) {
|
||||
for (const suffix of suffixes) {
|
||||
try {
|
||||
return artifactsRequire(name + suffix);
|
||||
return originalRequire.call(this, name + suffix);
|
||||
} catch (e) {
|
||||
// HH700: Artifact not found - from https://hardhat.org/hardhat-runner/docs/errors#HH700
|
||||
if (HardhatError.isHardhatError(e) && e.number === 700 && suffix !== '') {
|
||||
if (isExpectedError(e, suffix)) {
|
||||
continue;
|
||||
} else {
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
}
|
||||
throw new Error('Unreachable');
|
||||
};
|
||||
|
||||
// Ethers
|
||||
const originalReadArtifact = hre.artifacts.readArtifact;
|
||||
hre.artifacts.readArtifact = async function (name) {
|
||||
for (const suffix of suffixes) {
|
||||
try {
|
||||
return await originalReadArtifact.call(this, name + suffix);
|
||||
} catch (e) {
|
||||
if (isExpectedError(e, suffix)) {
|
||||
continue;
|
||||
} else {
|
||||
throw e;
|
||||
|
||||
Reference in New Issue
Block a user