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

feat: Add parsing to deploy to support new constructor feature #1574

Merged
merged 42 commits into from
Nov 6, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
8cd6747
feat: Add parsing to deploy to support new constructor feature
willemneal Aug 28, 2024
3abef23
Merge branch 'main' into feat/deploy_with_constructor
willemneal Sep 9, 2024
1b0c832
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Sep 14, 2024
a91b360
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Sep 17, 2024
b9c1246
fix: update to newest soroban deps
willemneal Sep 17, 2024
f5a290a
feat(contract deploy): use new deploy and init operation
willemneal Sep 18, 2024
69bbb78
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Sep 18, 2024
e455f75
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Sep 24, 2024
caca864
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 1, 2024
02e174a
fix: add tests
willemneal Oct 1, 2024
808d190
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 4, 2024
ac7afcd
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 7, 2024
c9f41b5
feat: update to newest rpc
willemneal Oct 7, 2024
98dd942
fix: update tests to use new API
willemneal Oct 7, 2024
c4f1033
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 8, 2024
487ae2a
fix: update rpc dep
willemneal Oct 8, 2024
7bdb5f8
fix: update rpc dep
willemneal Oct 8, 2024
b5dde87
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 10, 2024
869d827
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 10, 2024
1923773
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 11, 2024
478a74f
fix: update to newer rpc that fixes parsing issues
willemneal Oct 11, 2024
e94fd9d
fix: update to quickstart PR and finish constructor test
willemneal Oct 12, 2024
7c1703d
fix: fmt
willemneal Oct 12, 2024
59b024a
update quickstart tag
leighmcculloch Oct 16, 2024
2263693
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 16, 2024
de4661a
Merge branch 'main' into feat/deploy_with_constructor
willemneal Oct 20, 2024
0af30fe
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 29, 2024
5c771d6
fix: use reverted RPC server
willemneal Oct 29, 2024
5d0b637
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 30, 2024
3109620
fix: use local key instead of looking up again
willemneal Oct 30, 2024
3d067fc
fix: revert RPC action to not use PR
willemneal Oct 30, 2024
b183ed5
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Oct 31, 2024
0c69876
Merge remote-tracking branch 'origin/main' into feat/deploy_with_cons…
willemneal Nov 5, 2024
fe06827
Merge branch 'main' into feat/deploy_with_constructor
leighmcculloch Nov 6, 2024
eb87e6b
undo huge number of dep changes
leighmcculloch Nov 6, 2024
6fc3f9a
revert change that seems like an unnecessary helper
leighmcculloch Nov 6, 2024
3fd3149
tweak cli message
leighmcculloch Nov 6, 2024
16be7e5
correct panic message
leighmcculloch Nov 6, 2024
6db67b3
remove unnecessary change
leighmcculloch Nov 6, 2024
49eab3a
undo unnecessary changes to reduce diff
leighmcculloch Nov 6, 2024
3d6498f
Revert "remove unnecessary change"
leighmcculloch Nov 6, 2024
5706e65
remove strkey lib use because it is just an extra type and we can use…
leighmcculloch Nov 6, 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
35 changes: 17 additions & 18 deletions .github/workflows/rpc-tests.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@

name: RPC Tests
on:
push:
Expand All @@ -15,32 +14,32 @@ jobs:
runs-on: ubuntu-22.04
services:
rpc:
image: stellar/quickstart:v438-testing
image: stellar/quickstart:testing
ports:
- 8000:8000
env:
ENABLE_LOGS: true
ENABLE_SOROBAN_DIAGNOSTIC_EVENTS: true
NETWORK: local
PROTOCOL_VERSION: 22
options: >-
--health-cmd "curl --no-progress-meter --fail-with-body -X POST \"http://localhost:8000/soroban/rpc\" -H 'Content-Type: application/json' -d '{\"jsonrpc\":\"2.0\",\"id\":8675309,\"method\":\"getNetwork\"}' && curl --no-progress-meter \"http://localhost:8000/friendbot\" | grep '\"invalid_field\": \"addr\"'"
--health-interval 10s
--health-timeout 5s
--health-retries 50
steps:
- uses: actions/checkout@v4
- uses: actions/cache@v4
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
target/
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
- run: rustup update
- run: cargo build
- run: rustup target add wasm32-unknown-unknown
- run: make build-test-wasms
- run: SOROBAN_PORT=8000 cargo test --features it --package soroban-test --test it -- integration

- uses: actions/checkout@v4
- uses: actions/cache@v4
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
target/
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.lock') }}
- run: rustup update
- run: cargo build
- run: rustup target add wasm32-unknown-unknown
- run: make build-test-wasms
- run: SOROBAN_PORT=8000 cargo test --features it --package soroban-test --test it -- integration
12 changes: 12 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

11 changes: 9 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,15 @@ members = [
"cmd/crates/soroban-test/tests/fixtures/hello",
"cmd/crates/soroban-test/tests/fixtures/bye",
]
default-members = ["cmd/soroban-cli", "cmd/crates/soroban-spec-tools", "cmd/crates/soroban-test"]
exclude = ["cmd/crates/soroban-test/tests/fixtures/hello", "cmd/crates/soroban-test/tests/fixtures/bye"]
default-members = [
"cmd/soroban-cli",
"cmd/crates/soroban-spec-tools",
"cmd/crates/soroban-test",
]
exclude = [
"cmd/crates/soroban-test/tests/fixtures/hello",
"cmd/crates/soroban-test/tests/fixtures/bye",
]

[workspace.package]
version = "21.5.0"
Expand Down
6 changes: 5 additions & 1 deletion FULL_HELP_DOCS.md
Original file line number Diff line number Diff line change
Expand Up @@ -388,7 +388,11 @@ If no keys are specified the contract itself is extended.

Deploy a wasm contract

**Usage:** `stellar contract deploy [OPTIONS] --source-account <SOURCE_ACCOUNT> <--wasm <WASM>|--wasm-hash <WASM_HASH>>`
**Usage:** `stellar contract deploy [OPTIONS] --source-account <SOURCE_ACCOUNT> <--wasm <WASM>|--wasm-hash <WASM_HASH>> [-- <CONTRACT_CONSTRUCTOR_ARGS>...]`

###### **Arguments:**

* `<CONTRACT_CONSTRUCTOR_ARGS>` — If provided, will be passed to the contract's `__constructor` function with provided arguments for that function as `--arg-name value`

###### **Options:**

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
[package]
name = "test_constructor"
version = "21.5.0"
authors = ["Stellar Development Foundation <[email protected]>"]
license = "Apache-2.0"
edition = "2021"
publish = false
rust-version.workspace = true

[lib]
crate-type = ["cdylib"]
doctest = false

[dependencies]
soroban-sdk = { workspace = true }

[dev-dependencies]
soroban-sdk = { workspace = true, features = ["testutils"]}
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
#![no_std]
use soroban_sdk::{contract, contractimpl, symbol_short, Env, Symbol};

#[contract]
pub struct Contract;
const COUNTER: Symbol = symbol_short!("COUNTER");

#[contractimpl]
impl Contract {
/// Example constructor
pub fn __constructor(env: Env, counter: u32) {
env.storage().persistent().set(&COUNTER, &counter);
}
/// Counter value
pub fn counter(env: Env) -> u32 {
env.storage().persistent().get(&COUNTER).unwrap()
}
}
1 change: 1 addition & 0 deletions cmd/crates/soroban-test/tests/it/integration.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
mod bindings;
mod constructor;
mod cookbook;
mod custom_types;
mod dotenv;
Expand Down
73 changes: 73 additions & 0 deletions cmd/crates/soroban-test/tests/it/integration/constructor.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
use assert_cmd::Command;

use soroban_cli::xdr::{
self, CreateContractArgsV2, HostFunction, InvokeHostFunctionOp, Limits, OperationBody, ReadXdr,
Transaction, TransactionV1Envelope,
};
use soroban_test::{AssertExt, TestEnv};

use super::util::CONSTRUCTOR;

fn constructor_cmd(sandbox: &TestEnv, value: u32, arg: &str) -> Command {
let mut cmd = sandbox.new_assert_cmd("contract");
cmd.arg("deploy")
.arg("--wasm")
.arg(CONSTRUCTOR.path())
.arg("--alias=init");
if !arg.is_empty() {
cmd.arg(arg);
}
cmd.arg("--").arg("--counter").arg(value.to_string());
cmd
}

#[tokio::test]
async fn deploy_constructor_contract() {
let sandbox = TestEnv::new();
let value = 100;
let build = constructor_cmd(&sandbox, value, "--build-only")
.assert()
.stdout_as_str();
let tx = xdr::TransactionEnvelope::from_xdr_base64(&build, Limits::none()).unwrap();
let ops = if let xdr::TransactionEnvelope::Tx(TransactionV1Envelope {
tx: Transaction { operations, .. },
..
}) = tx
{
operations
} else {
panic!()
}
.to_vec();
let first = ops.first().unwrap();
let args = match first {
xdr::Operation {
body:
OperationBody::InvokeHostFunction(InvokeHostFunctionOp {
host_function:
HostFunction::CreateContractV2(CreateContractArgsV2 {
constructor_args, ..
}),
..
}),
..
} => constructor_args,
_ => panic!("expected invoke host function with create contract v2"),
}
.to_vec();

match args.first().unwrap() {
xdr::ScVal::U32(u32) => assert_eq!(*u32, value),
_ => panic!("Expected U32"),
}

constructor_cmd(&sandbox, value, "").assert().success();

let res = sandbox
.new_assert_cmd("contract")
.args(["invoke", "--id=init", "--", "counter"])
.assert()
.success()
.stdout_as_str();
assert_eq!(res.trim(), value.to_string());
}
1 change: 1 addition & 0 deletions cmd/crates/soroban-test/tests/it/integration/util.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ use soroban_test::{TestEnv, Wasm};
use std::fmt::Display;

pub const HELLO_WORLD: &Wasm = &Wasm::Custom("test-wasms", "test_hello_world");
pub const CONSTRUCTOR: &Wasm = &Wasm::Custom("test-wasms", "test_constructor");
pub const CUSTOM_TYPES: &Wasm = &Wasm::Custom("test-wasms", "test_custom_types");
pub const CUSTOM_ACCOUNT: &Wasm = &Wasm::Custom("test-wasms", "test_custom_account");
pub const SWAP: &Wasm = &Wasm::Custom("test-wasms", "test_swap");
Expand Down
6 changes: 3 additions & 3 deletions cmd/soroban-cli/src/commands/contract/deploy/asset.rs
Original file line number Diff line number Diff line change
Expand Up @@ -93,11 +93,11 @@ impl NetworkRunnable for Cmd {
.verify_network_passphrase(Some(&network.network_passphrase))
.await?;
let source_account = config.source_account()?;

// Get the account sequence number
let public_strkey = source_account.to_string();
// TODO: use symbols for the method names (both here and in serve)
let account_details = client.get_account(&public_strkey).await?;
let account_details = client
.get_account(&source_account.clone().to_string())
.await?;
let sequence: i64 = account_details.seq_num.into();
let network_passphrase = &network.network_passphrase;
let contract_id = contract_id_hash_from_asset(asset, network_passphrase);
Expand Down
Loading
Loading