Skip to content

Commit

Permalink
Update to solang v0.3.2 and add simple test (#2636)
Browse files Browse the repository at this point in the history
  • Loading branch information
seanyoung authored Sep 26, 2023
1 parent 28adaf2 commit 3e8bc76
Show file tree
Hide file tree
Showing 17 changed files with 197 additions and 15 deletions.
14 changes: 13 additions & 1 deletion .github/actions/setup-solana/action.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ runs:
path: |
~/.cache/solana/
~/.local/share/solana/
key: solana-${{ runner.os }}-v0000-${{ env.SOLANA_CLI_VERSION }}
key: solana-${{ runner.os }}-v0000-${{ env.SOLANA_CLI_VERSION }}-${{ env.SOLANG_VERSION }}
- uses: nick-fields/retry@v2
if: steps.cache-solana.outputs.cache-hit != 'true'
with:
Expand All @@ -20,6 +20,18 @@ runs:
retry_on: error
shell: bash
command: sh -c "$(curl -sSfL https://release.solana.com/v${{ env.SOLANA_CLI_VERSION }}/install)"
- uses: nick-fields/retry@v2
if: steps.cache-solana.outputs.cache-hit != 'true'
with:
retry_wait_seconds: 300
timeout_minutes: 2
max_attempts: 10
retry_on: error
shell: bash
command: |
curl -sSL -o /home/runner/.local/share/solana/install/active_release/bin/solang \
https://github.com/hyperledger/solang/releases/download/v${{ env.SOLANG_VERSION }}/solang-linux-x86-64
chmod 755 /home/runner/.local/share/solana/install/active_release/bin/solang
- run: echo "/home/runner/.local/share/solana/install/active_release/bin" >> $GITHUB_PATH
shell: bash
- run: solana-keygen new --no-bip39-passphrase
Expand Down
1 change: 1 addition & 0 deletions .github/workflows/no-caching-tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ jobs:
with:
cache: false
solana_cli_version: 1.16.0
solang_version: 0.3.2
node_version: 17.0.1
cargo_profile: release
anchor_binary_name: anchor-binary-no-caching
6 changes: 6 additions & 0 deletions .github/workflows/reusable-tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ on:
solana_cli_version:
required: true
type: string
solang_version:
required: true
type: string
node_version:
required: true
type: string
Expand All @@ -21,6 +24,7 @@ on:
env:
CACHE: inputs.cache
SOLANA_CLI_VERSION: ${{ inputs.solana_cli_version }}
SOLANG_VERSION: ${{ inputs.solang_version }}
NODE_VERSION: ${{ inputs.node_version }}
CARGO_PROFILE: ${{ inputs.cargo_profile }}
ANCHOR_BINARY_NAME: ${{ inputs.anchor_binary_name }}
Expand Down Expand Up @@ -445,6 +449,8 @@ jobs:
path: tests/bench
- cmd: cd tests/idl && ./test.sh
path: tests/idl
- cmd: cd tests/solang && anchor test
path: tests/solang
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/setup/
Expand Down
1 change: 1 addition & 0 deletions .github/workflows/tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ jobs:
with:
cache: true
solana_cli_version: 1.16.0
solang_version: 0.3.2
node_version: 17.0.1
cargo_profile: debug
anchor_binary_name: anchor-binary
15 changes: 12 additions & 3 deletions Cargo.lock

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

2 changes: 1 addition & 1 deletion cli/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ solana-cli-config = ">=1.14, <1.17"
solana-faucet = ">=1.14, <1.17"
solana-program = ">=1.14, <1.17"
solana-sdk = ">=1.14, <1.17"
solang-parser = "=0.3.1"
solang-parser = "=0.3.2"
syn = { version = "1.0.60", features = ["full", "extra-traits"] }
tar = "0.4.35"
toml = "0.7.6"
Expand Down
11 changes: 10 additions & 1 deletion cli/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,8 @@ impl Manifest {
let mut cwd_opt = Some(start_from.as_path());

while let Some(cwd) = cwd_opt {
let mut anchor_toml = false;

for f in fs::read_dir(cwd).with_context(|| {
format!("Error reading the directory with path: {}", cwd.display())
})? {
Expand All @@ -127,10 +129,17 @@ impl Manifest {
let m = WithPath::new(Manifest::from_path(&p)?, p);
return Ok(Some(m));
}
if filename.to_str() == Some("Anchor.toml") {
anchor_toml = true;
}
}
}

// Not found. Go up a directory level.
// Not found. Go up a directory level, but don't go up from Anchor.toml
if anchor_toml {
break;
}

cwd_opt = cwd.parent();
}

Expand Down
23 changes: 15 additions & 8 deletions cli/src/solidity_template.rs
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ contract {} {{
bool private value = true;
@payer(payer)
constructor(address payer) {{
constructor() {{
print("Hello, World!");
}}
Expand Down Expand Up @@ -318,22 +318,27 @@ describe("{}", () => {{
it("Is initialized!", async () => {{
// Add your test here.
const tx = await program.methods.new(wallet.publicKey)
const tx = await program.methods
.new()
.accounts({{ dataAccount: dataAccount.publicKey }})
.signers([dataAccount]).rpc();
.signers([dataAccount])
.rpc();
console.log("Your transaction signature", tx);
const val1 = await program.methods.get()
const val1 = await program.methods
.get()
.accounts({{ dataAccount: dataAccount.publicKey }})
.view();
console.log("state", val1);
await program.methods.flip()
await program.methods
.flip()
.accounts({{ dataAccount: dataAccount.publicKey }})
.rpc();
const val2 = await program.methods.get()
const val2 = await program.methods
.get()
.accounts({{ dataAccount: dataAccount.publicKey }})
.view();
Expand Down Expand Up @@ -366,9 +371,11 @@ describe("{}", () => {{
it("Is initialized!", async () => {{
// Add your test here.
const tx = await program.methods.new(wallet.publicKey)
const tx = await program.methods
.new()
.accounts({{ dataAccount: dataAccount.publicKey }})
.signers([dataAccount]).rpc();
.signers([dataAccount])
.rpc();
console.log("Your transaction signature", tx);
}});
}});
Expand Down
3 changes: 2 additions & 1 deletion tests/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,8 @@
"cpi-returns",
"multiple-suites",
"multiple-suites-run-single",
"bpf-upgradeable-state"
"bpf-upgradeable-state",
"solang"
],
"dependencies": {
"@project-serum/common": "^0.0.1-beta.3",
Expand Down
8 changes: 8 additions & 0 deletions tests/solang/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@

.anchor
.DS_Store
target
**/*.rs.bk
node_modules
test-ledger
.yarn
8 changes: 8 additions & 0 deletions tests/solang/.prettierignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@

.anchor
.DS_Store
target
node_modules
dist
build
test-ledger
13 changes: 13 additions & 0 deletions tests/solang/Anchor.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
[features]
seeds = false
skip-lint = false

[programs.localnet]
flipper = "F1ipperKF9EfD821ZbbYjS319LXYiBmjhzkkf5a26rC"

[provider]
cluster = "Localnet"
wallet = "~/.config/solana/id.json"

[scripts]
test = "yarn run ts-mocha -p ./tsconfig.json -t 1000000 tests/**/*.ts"
12 changes: 12 additions & 0 deletions tests/solang/migrations/deploy.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
// Migrations are an early feature. Currently, they're nothing more than this
// single deploy script that's invoked from the CLI, injecting a provider
// configured from the workspace's Anchor.toml.

const anchor = require("@coral-xyz/anchor");

module.exports = async function (provider) {
// Configure client to use the provider.
anchor.setProvider(provider);

// Add your deploy script here.
};
19 changes: 19 additions & 0 deletions tests/solang/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
{
"name": "solang",
"version": "0.28.0",
"license": "(MIT OR Apache-2.0)",
"homepage": "https://github.com/coral-xyz/anchor#readme",
"bugs": {
"url": "https://github.com/coral-xyz/anchor/issues"
},
"repository": {
"type": "git",
"url": "https://github.com/coral-xyz/anchor.git"
},
"engines": {
"node": ">=11"
},
"scripts": {
"test": "anchor run test-with-build"
}
}
22 changes: 22 additions & 0 deletions tests/solang/solidity/flipper.sol
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@

@program_id("F1ipperKF9EfD821ZbbYjS319LXYiBmjhzkkf5a26rC")
contract flipper {
bool private value = true;

@payer(payer)
constructor() {
print("Hello, World!");
}

/// A message that can be called on instantiated contracts.
/// This one flips the value of the stored `bool` from `true`
/// to `false` and vice versa.
function flip() public {
value = !value;
}

/// Simply returns the current value of our `bool`.
function get() public view returns (bool) {
return value;
}
}
43 changes: 43 additions & 0 deletions tests/solang/tests/solang.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
import * as anchor from "@coral-xyz/anchor";
import { Program } from "@coral-xyz/anchor";
import { Flipper } from "../target/types/flipper";

describe("flipper", () => {
// Configure the client to use the local cluster.
const provider = anchor.AnchorProvider.env();
anchor.setProvider(provider);

const dataAccount = anchor.web3.Keypair.generate();
const wallet = provider.wallet;

const program = anchor.workspace.Flipper as Program<Flipper>;

it("Is initialized!", async () => {
// Add your test here.
const tx = await program.methods
.new()
.accounts({ dataAccount: dataAccount.publicKey })
.signers([dataAccount])
.rpc();
console.log("Your transaction signature", tx);

const val1 = await program.methods
.get()
.accounts({ dataAccount: dataAccount.publicKey })
.view();

console.log("state", val1);

await program.methods
.flip()
.accounts({ dataAccount: dataAccount.publicKey })
.rpc();

const val2 = await program.methods
.get()
.accounts({ dataAccount: dataAccount.publicKey })
.view();

console.log("state", val2);
});
});
11 changes: 11 additions & 0 deletions tests/solang/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"compilerOptions": {
"types": ["mocha", "chai"],
"typeRoots": ["./node_modules/@types"],
"lib": ["es2015"],
"module": "commonjs",
"target": "es6",
"esModuleInterop": true,
"skipLibCheck": true
}
}

1 comment on commit 3e8bc76

@vercel
Copy link

@vercel vercel bot commented on 3e8bc76 Sep 26, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Successfully deployed to the following URLs:

anchor-docs – ./

anchor-docs-git-master-200ms.vercel.app
www.anchor-lang.com
anchor-lang.com
anchor-docs-200ms.vercel.app

Please sign in to comment.