Execute Scripts
How to execute scripts
It is often the case that you need to query the current state of the network. For example, to check balance of an
account, read public values of a contract or ensure that a user has a specific resource in their storage.
We abstract this interaction into a single method called executeScript
. Method have 2 different signatures.
⚠️ Required: Your project must follow the required structure it must be initialized to use the following functions.
executeScript(props)
Provides explicit control over how you pass values.
Arguments
props
object accepts following fields:
Name | Type | Optional | Description |
---|---|---|---|
code | string | ✅ | string representation of Cadence script |
name | string | ✅ | name of the file in scripts folder to use (sans .cdc extension) |
args | [Any] | ✅ | an array of arguments to pass to script. Optional if script does not expect any arguments. |
⚠️ Required: Either
code
orname
field shall be specified. Method will throw an error if both of them are empty. Ifname
field provided, framework will source code from file and override value passed viacode
field.
Usage
import path from "path";
import { init, emulator, executeScript } from "flow-js-testing";
const main = async () => {
const basePath = path.resolve(__dirname, "../cadence");
const port = 8080;
// Init framework
init(basePath, { port });
// Start emulator
await emulator.start(port);
// Define code and arguments we want to pass
const code = `
pub fun main(message: String): Int{
log(message)
return 42
}
`;
const args = ["Hello, from Cadence"];
// If something goes wrong with script execution method will throw an error,
// so we need to catch it and process
try {
const result = await executeScript({ code, args });
console.log({ result });
} catch (e) {
console.error(e);
}
// Stop emulator instance
await emulator.stop();
};
main();
executeScript(name: string, args: [any])
This signature provides simplified way of executing a script, since most of the time you will utilize existing Cadence files.
Arguments
Name | Type | Optional | Description |
---|---|---|---|
name | string | name of the file in scripts folder to use (sans .cdc extension) | |
args | [Any] | ✅ | an array of arguments to pass to script. Optional if scripts don't expect any arguments. Default: [] |
Usage
import path from "path";
import { init, emulator, executeScript } from "flow-js-testing";
const main = async () => {
const basePath = path.resolve(__dirname, "../cadence");
const port = 8080;
// Init framework
init(basePath, port);
// Start emulator
await emulator.start(port, false);
// Define arguments we want to pass
const args = ["Hello, from Cadence"];
// If something wrong with script execution method will throw an error,
// so we need to catch it and process
try {
// We assume there is a file `scripts/log-message.cdc` under base path
const result = await executeScript("log-message", args);
console.log({ result });
} catch (e) {
console.error(e);
}
await emulator.stop();
};
main();
📣 Note about method usage