From 208e38803c5507a7814b65e099dc81ca92390b09 Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Wed, 23 Mar 2022 22:48:41 +0300 Subject: [PATCH] neotest: add some high-level documentation --- pkg/neotest/chain/doc.go | 7 +++++++ pkg/neotest/doc.go | 18 ++++++++++++++++++ 2 files changed, 25 insertions(+) create mode 100644 pkg/neotest/chain/doc.go create mode 100644 pkg/neotest/doc.go diff --git a/pkg/neotest/chain/doc.go b/pkg/neotest/chain/doc.go new file mode 100644 index 000000000..1b0d6f286 --- /dev/null +++ b/pkg/neotest/chain/doc.go @@ -0,0 +1,7 @@ +/* +Package chain contains functions creating new test blockchain instances. +Different configurations can be used, but all chains created here use +well-known keys. Most of the time single-node chain is the best choice to use +unless you specifically need multiple validators and large committee. +*/ +package chain diff --git a/pkg/neotest/doc.go b/pkg/neotest/doc.go new file mode 100644 index 000000000..a86dc4615 --- /dev/null +++ b/pkg/neotest/doc.go @@ -0,0 +1,18 @@ +/* +Package neotest contains framework for automated contract testing. +It can be used to implement unit-tests for contracts in Go using regular Go +conventions. + +Usually it's used like this: + * an instance of blockchain is created using chain subpackage + * target contract is compiled using one of Compile* functions + * and Executor is created for blockchain + * it's used to deploy contract with DeployContract + * CommitteeInvoker and/or ValidatorInvoker are then created to perform test invocations + * if needed NewAccount is used to create appropriate number of accounts for the test + +Higher-order methods provided in Executor and ContractInvoker hide the details +of transaction creation for the most part, but there are lower-level methods as +well that can be used for specific tasks. +*/ +package neotest