Skip to content

Commit

Permalink
Merge pull request NomicFoundation#2007 from nomiclabs/show-error-old…
Browse files Browse the repository at this point in the history
…er-solc

Throw error for old solc versions
  • Loading branch information
fvictorio authored Nov 1, 2021
2 parents 730353d + c099415 commit 6aa3268
Show file tree
Hide file tree
Showing 9 changed files with 100 additions and 1 deletion.
5 changes: 5 additions & 0 deletions .changeset/early-pillows-bathe.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"hardhat": patch
---

Throw an error for solc versions older than 0.4.11
14 changes: 14 additions & 0 deletions packages/hardhat-core/src/builtin-tasks/compile.ts
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,8 @@ function isConsoleLogError(error: any): boolean {

const log = debug("hardhat:core:tasks:compile");

const COMPILE_TASK_FIRST_SOLC_VERSION_SUPPORTED = "0.4.11";

/**
* Returns a list of absolute paths to all the solidity files in the project.
* This list doesn't include dependencies, for example solidity files inside
Expand Down Expand Up @@ -643,6 +645,18 @@ subtask(TASK_COMPILE_SOLIDITY_COMPILE_SOLC)
},
{ run }
): Promise<{ output: CompilerOutput; solcBuild: SolcBuild }> => {
// versions older than 0.4.11 don't work with hardhat
// see issue https://github.com/nomiclabs/hardhat/issues/2004
if (semver.lt(solcVersion, COMPILE_TASK_FIRST_SOLC_VERSION_SUPPORTED)) {
throw new HardhatError(
ERRORS.BUILTIN_TASKS.COMPILE_TASK_UNSUPPORTED_SOLC_VERSION,
{
version: solcVersion,
firstSupportedVersion: COMPILE_TASK_FIRST_SOLC_VERSION_SUPPORTED,
}
);
}

const solcBuild: SolcBuild = await run(
TASK_COMPILE_SOLIDITY_GET_SOLC_BUILD,
{
Expand Down
10 changes: 10 additions & 0 deletions packages/hardhat-core/src/internal/core/errors-list.ts
Original file line number Diff line number Diff line change
Expand Up @@ -861,6 +861,16 @@ To start the JSON-RPC server, retry the command without the --network parameter.
if the URL of the JSON-RPC wasn't set.`,
shouldBeReported: false,
},
COMPILE_TASK_UNSUPPORTED_SOLC_VERSION: {
number: 608,
message: `Version %version% is not supported by Hardhat.
The first supported version is %firstSupportedVersion%`,
title: "Unsupported solc version",
description: `This version of solidity is not supported by Hardhtat.
Please use a newer, supported version.`,
shouldBeReported: true,
},
},
ARTIFACTS: {
NOT_FOUND: {
Expand Down
36 changes: 36 additions & 0 deletions packages/hardhat-core/test/builtin-tasks/compile.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,11 @@ import * as path from "path";

import { TASK_COMPILE_SOLIDITY_GET_COMPILATION_JOBS_FAILURE_REASONS } from "../../src/builtin-tasks/task-names";
import { SOLIDITY_FILES_CACHE_FILENAME } from "../../src/internal/constants";
import { ERRORS } from "../../src/internal/core/errors-list";
import { globSync } from "../../src/internal/util/glob";
import { CompilationJobCreationErrorReason } from "../../src/types/builtin-tasks";
import { useEnvironment } from "../helpers/environment";
import { expectHardhatErrorAsync } from "../helpers/errors";
import { useFixtureProject } from "../helpers/project";
import { mockFile } from "../utils/mock-file";

Expand Down Expand Up @@ -709,4 +711,38 @@ Read about compiler configuration at https://hardhat.org/config
);
});
});

describe("old versions of solidity", function () {
useFixtureProject("old-solidity-versions");

describe("project with an old version of solidity", function () {
useEnvironment("old-solidity-version.js");

it("should throw an error", async function () {
await expectHardhatErrorAsync(async () => {
await this.env.run("compile");
}, ERRORS.BUILTIN_TASKS.COMPILE_TASK_UNSUPPORTED_SOLC_VERSION);
});
});

describe("project with an old version of solidity (multiple compilers)", function () {
useEnvironment("old-solidity-version-multiple-compilers.js");

it("should throw an error", async function () {
await expectHardhatErrorAsync(async () => {
await this.env.run("compile");
}, ERRORS.BUILTIN_TASKS.COMPILE_TASK_UNSUPPORTED_SOLC_VERSION);
});
});

describe("project with an old version of solidity in an override", function () {
useEnvironment("old-solidity-version-in-override.js");

it("should throw an error", async function () {
await expectHardhatErrorAsync(async () => {
await this.env.run("compile");
}, ERRORS.BUILTIN_TASKS.COMPILE_TASK_UNSUPPORTED_SOLC_VERSION);
});
});
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
pragma solidity ^0.4.0;

contract Foo {}
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
module.exports = {
solidity: {
compilers: [
{
version: "0.7.0",
},
],
overrides: {
"contracts/Foo.sol": { version: "0.4.8" },
},
},
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
module.exports = {
solidity: {
compilers: [
{
version: "0.8.6",
},
{
version: "0.4.9",
},
],
},
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
module.exports = {
solidity: "0.4.10",
};
6 changes: 5 additions & 1 deletion packages/hardhat-core/test/helpers/environment.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,16 @@ declare module "mocha" {
}
}

export function useEnvironment() {
export function useEnvironment(configPath?: string) {
beforeEach("Load environment", function () {
if (configPath !== undefined) {
process.env.HARDHAT_CONFIG = configPath;
}
this.env = require("../../src/internal/lib/hardhat-lib");
});

afterEach("reset hardhat context", function () {
delete process.env.HARDHAT_CONFIG;
resetHardhatContext();
});
}

0 comments on commit 6aa3268

Please sign in to comment.