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

rc: salamander #1495

Merged
merged 83 commits into from
Jan 26, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
83 commits
Select commit Hold shift + click to select a range
cd99e17
Adding RCs list
arboleya Dec 8, 2023
2b9495a
Ignoring RC labels
arboleya Dec 8, 2023
4dfd727
Configuring RC label
arboleya Dec 8, 2023
75ed18d
Re-configuring RC label
arboleya Dec 8, 2023
820b5e2
Adjusting PRs accepted labels
arboleya Dec 8, 2023
8b2c663
Merge branch 'master' into rc/salamander
arboleya Dec 10, 2023
8ebd388
chore: updating code owners (#1496)
arboleya Dec 12, 2023
4b3c8ea
Merge branch 'master' into rc/salamander
arboleya Dec 12, 2023
e12a62d
Merge branch 'master' into rc/salamander
arboleya Dec 13, 2023
c7b9b92
Merge branch 'master' into rc/salamander
arboleya Dec 13, 2023
cdc3e84
Merge branch 'master' into rc/salamander
arboleya Dec 13, 2023
8bea836
docs: purge hardcoded snippets on 'using typegen' page (#1403)
Dhaiwat10 Dec 14, 2023
5d5c939
chore: remove method that's same as base method (#1445)
nedsalk Dec 14, 2023
cd7aed5
Merge branch 'master' into rc/salamander
arboleya Dec 14, 2023
5261579
chore: implement RC workflow (#1497)
danielbate Dec 15, 2023
6a1c2f1
chore: fix rc release string replace (#1529)
danielbate Dec 15, 2023
b52c137
Merge branch 'master' into rc/salamander
arboleya Dec 15, 2023
e236fc8
Merge branch 'master' into rc/salamander
arboleya Dec 15, 2023
55e8301
docs: Update some hyperlinks to reference the new documentation hub (…
petertonysmith94 Dec 18, 2023
c5e56b4
Merge branch 'master' into rc/salamander
arboleya Dec 19, 2023
53ab0d6
chore: improve rc release message (#1559)
danielbate Dec 19, 2023
8021b38
feat: GraphQL subscriptions (#1374)
nedsalk Dec 20, 2023
58ef6e7
chore: pin `graphql-request` to `v5` (#1567)
danielbate Dec 20, 2023
e52a1cc
Merge branch 'master' into rc/salamander
arboleya Dec 20, 2023
5ebe5eb
chore: upgrade `tsx` (#1574)
danielbate Dec 20, 2023
5f12a6b
feat: migrate from Jest to Vitest (#1310)
danielbate Dec 21, 2023
92add1d
chore: fix temp test workflow (#1579)
danielbate Dec 21, 2023
76fee0e
Merge branch 'master' into rc/salamander
arboleya Dec 21, 2023
098c349
Fixing tsconfig.json
arboleya Dec 21, 2023
d759de2
chore: update required node engine in `create-fuels` (#1582)
danielbate Dec 21, 2023
576a46e
chore: add node version test matrix (#1575)
danielbate Dec 21, 2023
d3335de
chore: fix broken rc message (#1580)
danielbate Dec 22, 2023
c988199
chore: update nodejs to v20 (#1544)
nedsalk Dec 22, 2023
8d84846
feat: accepting addresses as `string` (#1583)
Torres-ssf Dec 22, 2023
773194c
chore: properly format the PR coverage report comment (#1586)
danielbate Dec 22, 2023
7949bb8
fix: flaky test (#1590)
Torres-ssf Dec 22, 2023
00e5850
docs: update `deposit-and-withdraw` page (#1591)
Torres-ssf Dec 23, 2023
563914e
feat: retry mechanism (#1474)
nedsalk Jan 3, 2024
87b7ce1
Merge branch 'master' into rc/salamander
arboleya Jan 3, 2024
7e46db9
Merge branch 'master' into rc/salamander
arboleya Jan 4, 2024
f698256
feat: replaced `semver` dependency with custom implementation (#1594)
nedsalk Jan 5, 2024
6c82640
feat: replace `elliptic` with `@noble/curves` (#1601)
nedsalk Jan 5, 2024
168a0e8
Merge branch 'master' into rc/salamander
arboleya Jan 5, 2024
ad7ee46
chore: fix CI failing due to missing tag in test (#1614)
nedsalk Jan 5, 2024
78e5e40
feat: improve ABI Coders `decode` validation (#1426)
danielbate Jan 5, 2024
ad5923d
Merge branch 'master' into rc/salamander
arboleya Jan 9, 2024
6796ef2
fix: do not generate a coverage diff without coverage artifact (#1629)
danielbate Jan 11, 2024
0668d88
Merge branch 'master' into rc/salamander
arboleya Jan 11, 2024
d31ee60
chore: pinpoint vitest to 1.0.4 (#1637)
arboleya Jan 12, 2024
db1df6b
chore: remove `ethers` dependency from `utils` (#1640)
danielbate Jan 12, 2024
14aebe7
fix: `getOperation` for `Transfer Asset` (#1619)
Torres-ssf Jan 15, 2024
b32dc96
fix: remove external font dependencies (#1642)
petertonysmith94 Jan 15, 2024
aac1b71
fix: generate RC PR comment on `pull_request` event only (#1648)
danielbate Jan 16, 2024
d41a26d
Merge branch 'master' into rc/salamander
arboleya Jan 16, 2024
de3cb15
fix: fix failing `rc` comment (#1657)
danielbate Jan 16, 2024
5236bfb
chore: add missing test group (#1658)
danielbate Jan 16, 2024
ed0a49f
Merge branch 'master' into rc/salamander
arboleya Jan 16, 2024
2682148
feat: implement browser compatibility testing (#1630)
danielbate Jan 17, 2024
1b0bb20
chore: fix string replace in `rc` ci (#1659)
danielbate Jan 17, 2024
403ee6a
chore: adding extra reporters (#1661)
arboleya Jan 17, 2024
587d445
chore: manually trigger `rc` CI (#1660)
danielbate Jan 17, 2024
45c32d0
Enabling PR auto-release
arboleya Jan 17, 2024
311fe7f
Fixing RC name resolution
arboleya Jan 17, 2024
1284d07
feat: use `submitAndAwait` graphql endpoint (#1615)
nedsalk Jan 18, 2024
26a370d
fix: flaky retry test (#1654)
nedsalk Jan 18, 2024
606e6e6
feat: create a wallet without a provider (#1566)
petertonysmith94 Jan 18, 2024
206c2fe
chore!: Share single chainConfig and review node-related utilities (#…
Dhaiwat10 Jan 18, 2024
901ae9b
Merge branch 'master' into rc/salamander
arboleya Jan 18, 2024
1d27e03
Merge branch 'master' into rc/salamander
arboleya Jan 23, 2024
82b336a
Lintfix
arboleya Jan 23, 2024
3b3458f
Lintfix
arboleya Jan 23, 2024
287b195
Lintfix
arboleya Jan 23, 2024
987eea4
chore: use new temporary coverage artifact (#1676)
danielbate Jan 23, 2024
ad17420
Merge branch 'master' into rc/salamander
arboleya Jan 24, 2024
d5298b6
Merge branch 'master' into rc/salamander
arboleya Jan 24, 2024
5f67bc1
Lintfix
arboleya Jan 24, 2024
dba7f8e
Lintfix
arboleya Jan 24, 2024
d81526e
Merge branch 'master' into rc/salamander
arboleya Jan 24, 2024
fbccf3f
fix: internalizing `findBinPath` utility (#1679)
arboleya Jan 24, 2024
5c8da10
Adjusting residual mistake after last merge from `master`
arboleya Jan 24, 2024
e126580
Merge branch 'master' into rc/salamander
arboleya Jan 26, 2024
fb505f9
Adding test group
arboleya Jan 26, 2024
2d6976e
Trigger CI
arboleya Jan 26, 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
docs: purge hardcoded snippets on 'using typegen' page (#1403)
* docs: purge hardcoded snippets on 'using typegen' page

* Update .gitignore

* delete typegen files

* fix formatting

* update ignore files

* refactor package.json

* fix author

Co-authored-by: Cameron Manavian <cameron.manavian@fuel.sh>

* fix author

Co-authored-by: Cameron Manavian <cameron.manavian@fuel.sh>

* update predicate test

* fix failing predicate test

* Fix authors

* add gasLimit

* update gas limit

---------

Co-authored-by: Cameron Manavian <cameron.manavian@fuel.sh>
Co-authored-by: Daniel Bate <djbate23@gmail.com>
  • Loading branch information
3 people authored Dec 14, 2023
commit 8bea83629fb6bbabe04a859eea531345f6821831
2 changes: 2 additions & 0 deletions .changeset/odd-kids-buy.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
---
---
4 changes: 3 additions & 1 deletion .eslintignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,9 @@ dist/
out/

apps/demo-fuels/src/sway-programs-api
apps/demo-typegen/src/generated-types
apps/demo-typegen/src/contract-types
apps/demo-typegen/src/script-types
apps/demo-typegen/src/predicate-types
apps/demo-nextjs
apps/demo-react-cra
apps/demo-react-vite
Expand Down
4 changes: 3 additions & 1 deletion .prettierignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,9 @@ apps/demo-fuels/src/sway-programs-api
apps/demo-nextjs
apps/demo-react-cra
apps/demo-react-vite
apps/demo-typegen/src/generated-types
apps/demo-typegen/src/contract-types
apps/demo-typegen/src/script-types
apps/demo-typegen/src/predicate-types
apps/docs/.vitepress/cache/

packages/fuels/test/fixtures/project
Expand Down
4 changes: 3 additions & 1 deletion apps/demo-typegen/.gitignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
node_modules
src/generated-types
src/contract-types
src/predicate-types
src/script-types

# Forc
**/out/debug/**
10 changes: 8 additions & 2 deletions apps/demo-typegen/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,14 @@
"author": "Fuel Labs <contact@fuel.sh> (https://fuel.network/)",
"scripts": {
"pretest": "run-s build:forc build:types",
"build:forc": "pnpm fuels-forc build -p contract",
"build:types": "pnpm fuels typegen -i contract/out/debug/demo-contract-abi.json -o src/generated-types"
"build:forc": "run-p forc:*",
"forc:contract": "pnpm fuels-forc build -p contract",
"forc:script": "pnpm fuels-forc build -p script",
"forc:predicate": "pnpm fuels-forc build -p predicate",
"build:types": "run-p types:*",
"types:contract": "pnpm fuels typegen -i contract/out/debug/demo-contract-abi.json -o src/contract-types",
"types:script": "pnpm fuels typegen -i script/out/debug/script-abi.json -o src/script-types --script",
"types:predicate": "pnpm fuels typegen -i predicate/out/debug/predicate-abi.json -o src/predicate-types --predicate"
},
"license": "Apache-2.0",
"dependencies": {
Expand Down
2 changes: 2 additions & 0 deletions apps/demo-typegen/predicate/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
out
target
7 changes: 7 additions & 0 deletions apps/demo-typegen/predicate/Forc.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
[project]
authors = ["Fuel Labs <contact@fuel.sh>"]
entry = "main.sw"
license = "Apache-2.0"
name = "predicate"

[dependencies]
5 changes: 5 additions & 0 deletions apps/demo-typegen/predicate/src/main.sw
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
predicate;

fn main() -> bool {
true
}
2 changes: 2 additions & 0 deletions apps/demo-typegen/script/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
out
target
7 changes: 7 additions & 0 deletions apps/demo-typegen/script/Forc.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
[project]
authors = ["Fuel Labs <contact@fuel.sh>"]
entry = "main.sw"
license = "Apache-2.0"
name = "script"

[dependencies]
5 changes: 5 additions & 0 deletions apps/demo-typegen/script/src/main.sw
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
script;

fn main() -> u8 {
10
}
102 changes: 97 additions & 5 deletions apps/demo-typegen/src/demo.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,24 +2,52 @@
import { safeExec } from '@fuel-ts/errors/test-utils';
import { generateTestWallet } from '@fuel-ts/wallet/test-utils';
import type { BN } from 'fuels';
import { ContractFactory, Provider, toHex, BaseAssetId, Wallet, FUEL_NETWORK_URL } from 'fuels';

import { DemoContractAbi__factory } from './generated-types';
import bytecode from './generated-types/DemoContractAbi.hex';
import {
ContractFactory,
Provider,
toHex,
BaseAssetId,
Wallet,
FUEL_NETWORK_URL,
Address,
} from 'fuels';

import storageSlots from '../contract/out/debug/demo-contract-storage_slots.json';

import { DemoContractAbi__factory } from './contract-types';
import bytecode from './contract-types/DemoContractAbi.hex';
import { PredicateAbi__factory } from './predicate-types';
import { ScriptAbi__factory } from './script-types';

let gasPrice: BN;
describe('ExampleContract', () => {
beforeAll(async () => {
const provider = await Provider.create(FUEL_NETWORK_URL);
({ minGasPrice: gasPrice } = provider.getGasConfig());
});
it('with imported storage slots', async () => {
const provider = await Provider.create(FUEL_NETWORK_URL);
const wallet = await generateTestWallet(provider, [[500_000, BaseAssetId]]);

// #region typegen-demo-contract-storage-slots
// #context import storageSlots from './contract/out/debug/demo-contract-storage_slots.json';

const contract = await DemoContractAbi__factory.deployContract(bytecode, wallet, {
storageSlots,
gasPrice,
});
// #endregion typegen-demo-contract-storage-slots

expect(contract.id).toBeTruthy();
});
it('should return the input', async () => {
const provider = await Provider.create(FUEL_NETWORK_URL);
const wallet = await generateTestWallet(provider, [[500_000, BaseAssetId]]);

// Deploy
const factory = new ContractFactory(bytecode, DemoContractAbi__factory.abi, wallet);
const contract = await factory.deployContract({ gasPrice });
const contractId = contract.id;

// Call
const { value } = await contract.functions
Expand All @@ -31,20 +59,29 @@ describe('ExampleContract', () => {
expect(value.toHex()).toEqual(toHex(1337));

// You can also make a call using the factory
const contractInstance = DemoContractAbi__factory.connect(contract.id, wallet);
// #region typegen-demo-contract-factory-connect
// #context import { DemoContractAbi__factory } from './types';

const contractInstance = DemoContractAbi__factory.connect(contractId, wallet);
const { value: v2 } = await contractInstance.functions
.return_input(1337)
.txParams({ gasPrice, gasLimit: 10_000 })
.call();
// #endregion typegen-demo-contract-factory-connect
expect(v2.toHex()).toBe(toHex(1337));
});

it('deployContract method', async () => {
const provider = await Provider.create(FUEL_NETWORK_URL);
const wallet = await generateTestWallet(provider, [[500_000, BaseAssetId]]);

// #region typegen-demo-contract-factory-deploy
// #context import { DemoContractAbi__factory } from './types';
// #context import bytecode from './types/DemoContractAbi.hex';

// Deploy
const contract = await DemoContractAbi__factory.deployContract(bytecode, wallet, { gasPrice });
// #endregion typegen-demo-contract-factory-deploy

// Call
const { value } = await contract.functions
Expand Down Expand Up @@ -89,3 +126,58 @@ it('should throw when dry running via contract factory with wallet with no resou

expect((<Error>error).message).toMatch('not enough coins to fit the target');
});

test('Example script', async () => {
const provider = await Provider.create(FUEL_NETWORK_URL);
const wallet = await generateTestWallet(provider, [[500_000, BaseAssetId]]);

// TODO: investigate why do we need to specify the gasLimit here. If we don't specify it, the call fails saying `FuelError: Gas limit '0' is lower than the required: '19'.`

// #region typegen-demo-script
// #context import { ScriptAbi__factory } from './types';

const script = ScriptAbi__factory.createInstance(wallet);
const { value } = await script.functions
.main()
.txParams({
gasPrice: provider.getGasConfig().minGasPrice,
gasLimit: 10_000,
})
.call();
// #endregion typegen-demo-script
// @ts-expect-error TODO: investitage - typegen is expecting value to be a number but the value being returned is the string '0xa'
expect(value.toNumber()).toBe(10);
});

test('Example predicate', async () => {
// #region typegen-demo-predicate
// #context import { PredicateAbi__factory } from './types';

// In this exchange, we are first transferring some coins to the predicate
const provider = await Provider.create(FUEL_NETWORK_URL);
const wallet = await generateTestWallet(provider, [[500_000, BaseAssetId]]);
const receiver = Wallet.fromAddress(Address.fromRandom(), provider);

const predicate = PredicateAbi__factory.createInstance(provider);

const tx = await wallet.transfer(predicate.address, 100_000, BaseAssetId, {
gasPrice: provider.getGasConfig().minGasPrice,
gasLimit: 50,
});
await tx.wait();

const initialPredicateBalance = await predicate.getBalance();

// Then we are transferring some coins from the predicate to a random address (receiver)
const tx2 = await predicate.transfer(receiver.address, 50_000, BaseAssetId, {
gasPrice: provider.getGasConfig().minGasPrice,
gasLimit: 50,
});
await tx2.wait();

expect((await receiver.getBalance()).toNumber()).toEqual(50_000);
expect((await predicate.getBalance()).toNumber()).toBeLessThan(
initialPredicateBalance.toNumber()
);
// #endregion typegen-demo-predicate
});
81 changes: 6 additions & 75 deletions apps/docs/src/guide/abi-typegen/using-generated-types.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,49 +10,19 @@ pnpm fuels typegen -i ./abis/*-abi.json -o ./types

We can use these files like so:

<!-- TODO: stop using hard-coded snippets -->

```ts
import { Wallet } from "fuels";
import { MyContract__factory } from "./types";

const contractId = "0x...";
const wallet = Wallet.fromAddress("...");
const contract = MyContract__factory.connect(contractId, wallet);

// All contract methods are available under functions with the correct types
const { transactionId, value } = await contract.functions.my_fn(1).call();

console.log(transactionId, value);
```
<<< @/../../demo-typegen/src/demo.test.ts#typegen-demo-contract-factory-connect{ts:line-numbers}

## Contract

Let's use the Contract class to deploy a contract:

```ts
import { Wallet } from "fuels";
import { MyContract__factory } from "./types";
import bytecode from "./types/MyContract.hex.ts";

const wallet = Wallet.fromAddress("...");

const contract = await MyContract__factory.deployContract(bytecode, wallet);

console.log(contract.id);
```
<<< @/../../demo-typegen/src/demo.test.ts#typegen-demo-contract-factory-deploy{ts:line-numbers}

### Autoloading of Storage Slots

Typegen tries to resolve, auto-load, and embed the [Storage Slots](../contracts//storage-slots.md) for your Contract within the `MyContract__factory` class. Still, you can override it alongside other options from [`DeployContractOptions`](https://github.com/FuelLabs/fuels-ts/blob/a64b67b9fb2d7f764ab9151a21d2266bf2df3643/packages/contract/src/contract-factory.ts#L19-L24), when calling the `deployContract` method:

```ts
import storageSlots from "../contract/out/debug/storage-slots.json";

const contract = await MyContract__factory.deployContract(bytecode, wallet, {
storageSlots,
});
```
<<< @/../../demo-typegen/src/demo.test.ts#typegen-demo-contract-storage-slots{ts:line-numbers}

## Script

Expand All @@ -64,58 +34,19 @@ pnpm fuels typegen -i ./abis/*-abi.json -o ./types --script

We can use these files like so:

<!-- TODO: stop using hard-coded snippets -->

```ts
import { Wallet } from "fuels";
import { MyScript__factory } from "./types";

const wallet = Wallet.fromAddress("...");
const script = ScriptAbi__factory.createInstance(wallet);

const { value, logs } = await script.functions.main(1).call();

console.log({ value, logs });
```
<<< @/../../demo-typegen/src/demo.test.ts#typegen-demo-script{ts:line-numbers}

## Predicate

Consider the following predicate:

<<< @/../../../packages/fuel-gauge/test/fixtures/forc-projects/predicate-main-args-struct/src/main.sw#Predicate-main-args{ts:line-numbers}

Now, after generating types via:
After generating types via:

```console
pnpm fuels typegen -i ./abis/*-abi.json -o ./types --predicate
```

We can use these files like so:

<!-- TODO: stop using hard-coded snippets -->

```ts
import { Wallet } from "fuels";
import { MyPredicate__factory } from "./types";

const wallet = Wallet.fromAddress("...");
const predicate = MyPredicate__factory.createInstance();

await predicate
.setData({
has_account: true,
total_complete: 100,
})
.transfer(wallet.address, <amount>);

const walletBalance = await wallet.getBalance();
const predicateBalance = await predicate.getBalance();

console.log({
walletBalance,
predicateBalance,
});
```
<<< @/../../demo-typegen/src/demo.test.ts#typegen-demo-predicate{ts:line-numbers}

See also:

Expand Down
4 changes: 3 additions & 1 deletion nodemon.config.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@
"**/Forc.lock",
"**/getBuiltinVersions.ts",
"**/out/debug/**",
"apps/demo-typegen/src/generated-types/**"
"apps/demo-typegen/src/contract-types/**",
"apps/demo-typegen/src/predicate-types/**",
"apps/demo-typegen/src/script-types/**"
]
}
Loading