Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Hardhat Tenderly is not compatible with Hardhat Preprocessor #127

Open
alexanderattar opened this issue Mar 27, 2023 · 2 comments
Open

Hardhat Tenderly is not compatible with Hardhat Preprocessor #127

alexanderattar opened this issue Mar 27, 2023 · 2 comments

Comments

@alexanderattar
Copy link

After much debugging trying to get the tenderly:verify function to work I've realized that these libraries are incompatible. I kept getting the error:

Error: There are multiple definitions of libraries the contract should use. One is defined in the verify request and the other as an compiler config override. Please remove one of them.

Due to these lines of code in util.js:

    if (compiler.settings.libraries !== undefined && compiler.settings.libraries !== null) {
        console.log(compiler.settings.libraries);
        throw new Error(`There are multiple definitions of libraries the contract should use. One is defined in the verify request and the other as an compiler config override. Please remove one of them.`);
    }

After logging the compiler.settings.libraries object I realized a cache buster was getting injected and causing this error to get thrown. Eventually I pinpointed it down to be a result of hardhat-preprocessor injecting this value.

Please consider rethinking how this is handled to avoid others from going down the same rabbit hole I had to 🙏

For context these are the relevant lines in hardhat-preprocessor index.js

        for (const compiler of hre.config.solidity.compilers) {
            compiler.settings.libraries = compiler.settings.libraries || {};
            compiler.settings.libraries[''] = compiler.settings.libraries[''] || {};
            compiler.settings.libraries[''] = {
                __CACHE_BREAKER__: cacheBreaker,
            };
        }
        content = transform(linePreProcessor.transform, { absolutePath }, content);
@simplyoptimistic
Copy link

Believe issue #126 is a duplicate of this. I also had this issue, and think it would be useful if this was fixed as foundry/hardhat hybrid repositories are somewhat common. My workaround was to duplicate the dependencies, and remap them in foundry so that they match hardhat (and remove hardhat-preprocessor).

@dule-git
Copy link
Contributor

dule-git commented Oct 24, 2024

Hello @alexanderattar,

Is the issue resolved for you in some of the newer versions of the plugin?

Or you are still having the same error?

Thanks for reporting!
Also, sorry for the research that you had to go to in order to RCA this :(

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants