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

[WIP] Feat: Upgrade Functionality #2

Open
wants to merge 38 commits into
base: master
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
171fd7a
refactor clearDBForVersion
Whytecrowe Feb 6, 2024
faaeba3
rename current db getter and add another one for deployed version
Whytecrowe Feb 6, 2024
bb93140
draft the BaseUpgradeMission for needed method placeholders and place…
Whytecrowe Feb 6, 2024
8e870b1
add an enum for all the possible operations for upgrade
Whytecrowe Feb 7, 2024
816e1eb
make version an optional field on IContractDbData
Whytecrowe Feb 7, 2024
0a47a31
fix wrongly named DB getters on base mission
Whytecrowe Feb 7, 2024
0b1cb3d
use the new enum in upgrade mission and add dbCopy method
Whytecrowe Feb 7, 2024
a6db753
refactor and make new deployer types for the upgradeProxy calls
Whytecrowe Feb 8, 2024
2690082
add upgradeProxy method that uses hardhat-upgrades under the hood
Whytecrowe Feb 8, 2024
a06fd5e
implement upgrade() method along with implementing other placeholders…
Whytecrowe Feb 8, 2024
e2c4954
extract tx awaiting logic on HardhatDeployer into it's own method and…
Whytecrowe Feb 8, 2024
f7aefa0
remove redundant bytecode comparison and try to rely on upgrades for …
Whytecrowe Feb 8, 2024
ae765c0
install HH related packages as devDeps
Whytecrowe Feb 10, 2024
b005b4d
add include field in tsconfig to only compile src folder
Whytecrowe Feb 10, 2024
deadf03
start refatoring types on HardhatDeployer
Whytecrowe Feb 10, 2024
b87f933
finish retyping HardhatDeployer
Whytecrowe Feb 12, 2024
e27d0c5
remove usage of IHardhatBase and ISignerBase from the main classes an…
Whytecrowe Feb 12, 2024
846c55b
remove IHardhatBase type and fix types in all existing classes
Whytecrowe Feb 12, 2024
04d0467
remove src and test folders from the package
Whytecrowe Feb 12, 2024
17cf776
start fixing tests
Whytecrowe Feb 12, 2024
b39a9cf
specify what goes into the module's package in package.json
Whytecrowe Feb 13, 2024
10aacd8
fix some base types
Whytecrowe Feb 13, 2024
eb1460c
Merge branch 'type-refactor' into feat/upgrade-logic
Whytecrowe Feb 13, 2024
cbe8bd9
add "clean" script and add that to the build
Whytecrowe Feb 13, 2024
a2437ac
fix types and patch holes, remove redundant type args everywhere
Whytecrowe Feb 13, 2024
43782b8
fix incorrect db getter calls
Whytecrowe Feb 16, 2024
f62d9b1
add methods to read all version docs from db
Whytecrowe Feb 16, 2024
af0b4a9
add source maps to tsconfig
Whytecrowe Feb 20, 2024
848cb5f
fix a bug in execute of Upgrade mission
Whytecrowe Feb 20, 2024
d72003a
Merge branch 'master' into feat/upgrade-logic
Whytecrowe Sep 12, 2024
9cab7a0
fix errors after update from master
Whytecrowe Sep 12, 2024
d3f5405
update hardhat and ethers packages
Whytecrowe Sep 12, 2024
b15d55f
fix versioner to archive only at the end of campaign run
Whytecrowe Sep 26, 2024
fdf798f
update eslint config
Whytecrowe Oct 1, 2024
3b03537
add bytecode comparison func draft
Whytecrowe Oct 1, 2024
b184460
start reworking upgrade determination logic after all the testing:
Whytecrowe Oct 1, 2024
5b14e5d
remove redundant deploy await method from deployer
Whytecrowe Oct 3, 2024
8356ca4
refactoring and new logic:
Whytecrowe Oct 3, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
finish retyping HardhatDeployer
  • Loading branch information
Whytecrowe committed Feb 12, 2024
commit b87f933a1910ccf4e52293049f7a59a8a545d3c3
2 changes: 1 addition & 1 deletion src/campaign/deploy-campaign.ts
Original file line number Diff line number Diff line change
@@ -20,7 +20,7 @@ export class DeployCampaign <
St extends IContractState<IContractV6>,
> {
state : ICampaignState<H, S, P, St>;
deployer : HardhatDeployer<H, S, P>;
deployer : HardhatDeployer<P>;
dbAdapter : MongoDBAdapter;
logger : TLogger;
config : IDeployCampaignConfig<S>;
2 changes: 1 addition & 1 deletion src/campaign/types.ts
Original file line number Diff line number Diff line change
@@ -68,7 +68,7 @@ export interface ICampaignArgs <
St extends IContractState,
> {
missions : Array<TDeployMissionCtor<H, S, P, St>>;
deployer : HardhatDeployer<H, S, P>;
deployer : HardhatDeployer<P>;
dbAdapter : MongoDBAdapter;
logger : TLogger;
config : IDeployCampaignConfig<S>;
8 changes: 5 additions & 3 deletions src/deployer/hardhat-deployer.ts
Original file line number Diff line number Diff line change
@@ -2,8 +2,10 @@ import { ITenderlyContractData, TDeployArgs, TProxyKind } from "../missions/type
import axios from "axios";
import { IContractV6 } from "../campaign/types";
import { IProviderBase, IHardhatDeployerArgs, TSigner, HardhatExtended } from "./types";
import { Contract } from "ethers";


// TODO upg: try and remove this general provider type if possible
export class HardhatDeployer <P extends IProviderBase> {
hre : HardhatExtended;
signer : TSigner;
@@ -41,7 +43,7 @@ export class HardhatDeployer <P extends IProviderBase> {
contractName : string;
args : TDeployArgs;
kind : TProxyKind;
}) : Promise<IContractV6> {
}) : Promise<Contract> {
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const contractFactory = await this.getFactory(contractName);
@@ -55,7 +57,7 @@ export class HardhatDeployer <P extends IProviderBase> {
} else {
const tx = await deployment.deploymentTransaction();
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
receipt = await this.provider.waitForTransaction(tx.hash, 3);
receipt = await this.provider.waitForTransaction(tx!.hash, 3);

return contractFactory.attach(receipt.contractAddress);
}
@@ -73,7 +75,7 @@ export class HardhatDeployer <P extends IProviderBase> {
} else {
const tx = await deployment.deploymentTransaction();
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
receipt = await this.provider.waitForTransaction(tx.hash, 3);
receipt = await this.provider.waitForTransaction(tx!.hash, 3);

return contractFactory.attach(receipt.contractAddress);
}