Skip to content

Commit

Permalink
Reimplement e2e-test for API & GUI with fabric operator (#81)
Browse files Browse the repository at this point in the history
* Remove all the old e2e test suites

Signed-off-by: Atsushi Neki <atsushin@fast.au.fujitsu.com>

* Add Ginkgo based BDD test suite for API e2e-test

Signed-off-by: Atsushi Neki <atsushin@fast.au.fujitsu.com>

* Include network bring up steps into GUI e2e-test

Using tools/operator of fabric-test repo

Signed-off-by: Atsushi Neki <atsushin@fast.au.fujitsu.com>

* Update azure pipeline setting

Signed-off-by: Atsushi Neki <atsushin@fast.au.fujitsu.com>

* Increase test coverage up to the same with the old test suite

Signed-off-by: Atsushi Neki <atsushin@fast.au.fujitsu.com>

* Fix alerts in LGTM analysis

Signed-off-by: Atsushi Neki <atsushin@fast.au.fujitsu.com>

* Fix floating version of some materials for e2e-test

Changed to specify a fixed commit of fabric-test

Signed-off-by: Atsushi Neki <atsushin@fast.au.fujitsu.com>
  • Loading branch information
nekia authored Mar 4, 2020
1 parent cd55792 commit d2af48b
Show file tree
Hide file tree
Showing 293 changed files with 3,381 additions and 50,707 deletions.
2 changes: 1 addition & 1 deletion .eslintignore
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,5 @@
**/client/src/components/Header/*.spec.js
**/client/src/components/App/*.spec.js
**/client/wdio.conf.js
**/client/test/*.js
**/client/e2e-test/*.js

13 changes: 12 additions & 1 deletion .eslintrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -212,6 +212,7 @@
"adminpw",
"adminroutes",
"aff",
"anchorpeer",
"Analytics",
"api",
"appconfig",
Expand Down Expand Up @@ -342,6 +343,8 @@
"ssl",
"stacktrace",
"statedb",
"stdout",
"stderr",
"superagent",
"svg",
"tbody",
Expand Down Expand Up @@ -425,7 +428,15 @@
"csurf",
"_csrf-hl-expl",
"Uint8",
"Uint8Array"
"Uint8Array",
"yml",
"gui",
"src",
"cwd",
"ordererorg1",
"samplecc",
"testorgschannel0",
"mynetwork"
],
"skipIfMatch": ["http://[^s]*"],
"skipWordIfMatch": ["^foobar.*$"],
Expand Down
3 changes: 0 additions & 3 deletions app/platform/fabric/e2e-test/.gitignore

This file was deleted.

272 changes: 62 additions & 210 deletions app/platform/fabric/e2e-test/README.md
Original file line number Diff line number Diff line change
@@ -1,256 +1,108 @@

<!-- (SPDX-License-Identifier: CC-BY-4.0) --> <!-- Ensure there is a newline before, and after, this line -->

# Test example for behave (BDD, Gherkin syntax)

```behave
Feature: Bootstrapping Hyperledger Explorer
As a user I want to be able to bootstrap Hyperledger Explorer
Scenario Outline: <consensus_type> : Bring up explorer and send requests to the basic REST API functions successfully
Given I have a bootstrapped fabric network of type <consensus_type>
Given the NETWORK_PROFILE environment variable is solo-tls-disabled
When an admin sets up a channel named "mychannel"
When an admin deploys chaincode at path "github.com/hyperledger/fabric/examples/chaincode/go/example02/cmd" with args ["init","a","1000","b","2000"] with name "mycc" on channel "mychannel"
When a user invokes on the channel "mychannel" using chaincode named "mycc" with args ["invoke","a","b","10"]
When I wait "3" seconds
When a user queries on the channel "mychannel" using chaincode named "mycc" with args ["query","a"]
Then a user receives a success response of 990
When I start explorer
Then the logs on explorer.mynetwork.com contains "Please open web browser to access :" within 20 seconds
# Need to wait enough until completing process a new BlockEvent
Given I wait "20" seconds
Given I set base URL to "http://localhost:8090"
When I make a GET request to "auth/networklist"
Then the response status code should equal 200
Then the response structure should equal "networklistResp"
Then JSON at path ".networkList" should equal [[ "first-network", {} ]]
```

# Setup


## Download tools & pull fabric images

```
$ curl -sSL http://bit.ly/2ysbOFE | bash -s -- 1.4.4 1.4.4 0.4.18 -s
```

## Prepare Explorer / Explorer-DB image

### Build images

```
$ cd /some/where/blockchain-explorer
$ ./build_docker_image.sh
```
# Ginkgo based end-to-end test for REST API

### Pull images
We need to test each REST API on actual fabric network automatically. To achieve this requirement efficiently, following to the same way with fabric-test repository is good option for us.

```
$ docker pull hyperledger/explorer
$ docker pull hyperledger/explorer-db
```
Fabric-test provides a collection of utilities used to test the core Hyperledger Fabric projects. In Explorer, we use `Fabric Network Operator` and `Performance Traffic Engine (PTE)` to manipulate fabric network from our test suite written by golang (for API e2e-test) and node.js (for GUI e2e-test). The tool currently offers golang package and CLI.

## Install python & pip
# Prerequisites

### For Linux (Ubuntu)
* Go 1.11.0 or above
* The following packages:
* github.com/onsi/ginkgo/ginkgo
* github.com/onsi/gomega/...
* gopkg.in/yaml.v2
* Fabric binaries downloaded in $PATH
* docker/docker-compose

```
$ apt-get install python python-pip
```
# Setup

### For macOS
## Download fabric-test repository and sync up the sub modules

macOS comes with Python so there's a chance pip is already installed on your machine, verify the version
```
$ python --version
$ pip --version
```
go get -d github.com/hyperledger/fabric-test
cd $GOPATH/src/github.com/hyperledger/fabric-test
git checkout release-1.4
git submodule update --init --recursive
git submodule foreach git checkout release-1.4

## Setup virtualenv

### For Linux (Ubuntu)

```
$ apt-get install virtualenv
$ cd /some/where/blockchain-explorer/app/platform/fabric/e2e-test/feature
$ virtualenv e2e-test
$ source e2e-test/bin/activate
(e2e-test) $
```

### For macOS
## Install the latest stable fabric-client node package into PTE tool directory

```
$ pip install virtualenv
$ cd /some/where/blockchain-explorer/app/platform/fabric/e2e-test/feature
$ virtualenv e2e-test
$ source e2e-test/bin/activate
(e2e-test) $
cd $GOPATH/src/github.com/hyperledger/fabric-test/tools/PTE
npm install fabric-client@1.4.5
npm install fabric-ca-client@1.4.5
```

## Install required packages

```
# At /some/where/blockchain-explorer/app/platform/fabric/e2e-test/feature on virtual env
(e2e-test) $ pip install -r requirement.txt
```
## Create symboric link to PTE tool

# Run test scenarios
We need to keep some directory layouts to work together correctly each component of tools provided by fabric-test.

```
# At /some/where/blockchain-explorer/app/platform/fabric/e2e-test/feature on virtual env
(e2e-test) $ behave ./explorer.feature
cd /some/where/blockchain-explorer/app/platform/fabric/e2e-test
ln -s $GOPATH/src/github.com/hyperledger/fabric-test/tools/PTE ./PTE
```

## Optional: Run test with npm
# Running test suite

```
$ cd /some/where/blockchain-explorer
$ npm install # To install npm-run-all package
$ npm run e2e-test
cd /some/where/blockchain-explorer/app/platform/fabric/e2e-test
ginkgo -v
```

# Tips

* To enable stdout while running scenarios
```
(e2e-test) $ behave --no-capture ./explorer.feature
```

* To execute only a certain scenario
```
# Specify with line number
(e2e-test) $ behave ./explorer.feature:111
```
or
```
# Specify with tag
(e2e-test) $ behave --tags=@basic ./explorer.feature
```

* To preserve the test runtime environment without clean up when finishing test
```diff
--- a/app/platform/fabric/e2e-test/feature/explorer.feature
+++ b/app/platform/fabric/e2e-test/feature/explorer.feature
@@ -145,7 +149,7 @@ Scenario: [balance-transfer] Register a new user and enroll successfully
Then the response parameter "status" should equal 200

@basic
-# @doNotDecompose
+@doNotDecompose
Scenario: [first-network] Not supported to register a new user and enroll
Given I start first-network
Given the NETWORK_PROFILE environment variable is first-network
```

# How to upgrade fabric-test environment

All files copied from the original fabric-test repository have not been modified. When upgrading the baseline of fabric-test, you only need to override them.

```
$ git clone --recurse-submodules https://github.com/hyperledger/fabric-test.git -b release-1.4
$ cd fabric-test
$ git checkout --recurse-submodules 64a5e04 # Choose a certain commit hash to be used for this upgrade
$ find fabric/examples/chaincode fabric-samples/chaincode chaincodes/ feature/ -type f | zip fabric-test_64a5e04.zip -@
$ cd /some/where/blockchain-explorer/app/platform/fabric/e2e-test
$ unzip -o /some/where/fabric-test_64a5e04.zip
```

## Added files for e2e-test environment

To add e2e-test support to explorer, we have added the following files over the original files from fabric-test repository.

```
app/platform/fabric/e2e-test/
.gitignore
README.md
feature/
explorer.feature
explorer_gui_e2e.feature
requirement.txt
docker-compose/
docker-compose-explorer.yaml
docker-compose-kafka-sd.yml
explorer-configs/
steps/
explorer_impl.py
json_responses.py
```
* You can easily debug test code written by golang with using delve or VSCode debug functionality.

# Project Structure

Feature files are intended to locate in `/app/platform/fabric/e2e-test/feature` folder. Corresponding steps are located in `/app/platform/fabric/e2e-test/feature/steps`.
Overall project structure is as follows:

```
app/platform/fabric/e2e-test/chaincodes/ // hyperledger/fabric-test
app/platform/fabric/e2e-test/fabric/ // hyperledger/fabric-test
app/platform/fabric/e2e-test/fabric-samples/ // hyperledger/fabric-test
app/platform/fabric/e2e-test/fabric-sdk-java/ // hyperledger/fabric-test
app/platform/fabric/e2e-test/feature/ // hyperledger/fabric-test
+-- requirement.txt // store python requirements
+-- environment.py // contains common actions related to scenarios (e.g. clearing headers after running each feature file)
+-- explorer.feature // feature files (Test Scenarios)
+-- explorer_gui_e2e.feature // feature files for GUI e2e test scenario
+-- configs/
+-- {UUID}/ // crypto and channel artifacts dyanamically generated everytime running the scenarios
+-- configtx.yaml // contains common steps definitions
+-- crypto.yaml // contains common steps definitions
+-- fabric-ca-server-config.yaml // contains common steps definitions
+-- docker-compose/
+-- docker-compose-*.yml // definition of containers to support a variety of test network topology
+-- docker-compose-explorer.yaml // definition of containers to bring up Hyperledger Explorer / Explorer DB
+-- docker-compose-kafka-sd.yml // definition of containers to add configurations for service discovery to fabric network
+-- explorer-configs/ // Configuration and Profile for each scenario
// You can specify which environments should be in use on each scenario by defining NETWORK_PROFILE env variable
+-- config-${NETWORK_PROFILE}.json // Configuration of Explorer for each network
+-- connection-profile/ // Profiles for each network
+-- ${NETWORK_PROFILE}.json
runTestSuite.sh
: Script to setup env and run test suite
+-- chaincode/
configs/config_multi.json
configs/config_single.json
configs/connection-profile/org1-network.json
configs/connection-profile/org2-network.json
: Configuration for Explorer used within the test suite
+-- steps/
docker-compose.yaml
: Docker compose file to bring up Explorer reside with fabric network managed by Operator tool
+-- *_impl.py // Existing steps for fabric-test repository environment to manipulating fabric network and asserting status
specs/apitest-network-spec.yml
: Configuration of fabric network. Used when bring up fabric network
+-- *_util.py // Utility functions for fabric-test repository environment
specs/apitest-input-multiprofile.yml
specs/apitest-input-singleprofile.yml
specs/apitest-input-singleprofile_addnewch.yml
: Configuration for interacting to fabric network. Used when take actions like creating channel, joining to channel, etc.
+-- explorer_impl.py // New added steps for the e2e test of Hyperledger Explorer
specs/apitest_suite_test.go
specs/apitest_test.go
: Test suite
+-- json_responses.py // response data structures described in Trafaret format
specs/genchannelartifacts.sh
specs/runexplorer.sh
specs/stopexplorer.sh
: Scritps executed via test suite
app/platform/fabric/e2e-test/README.md
specs/templates/configtx.yaml
specs/templates/crypto-config.yaml
specs/templates/docker/docker-compose.yaml
: Template file following to yaml.v2 package format. Used to generate artifacts for fabric network automatically
```

Mainly we'll update `explorer.feature`, `steps/explorer_impl.py` and `steps/json_responses.py` to cover more scenarios.
Mainly we'll update `specs/apitest_test.go` to cover more scenarios.

# Link

* https://behave.readthedocs.io/en/latest/index.html
* https://github.com/hyperledger/fabric-test/tree/release-1.4/feature
The Explorer e2e test environment is based on the fabric-test env
* https://github.com/stanfy/behave-rest
This package is used to test REST API call in the BDD
* https://github.com/hyperledger/fabric-test
* https://github.com/hyperledger/fabric-test/tree/master/tools/operator
* https://github.com/hyperledger/fabric-test/tree/master/tools/PTE
* http://onsi.github.io/ginkgo/
* http://onsi.github.io/gomega/
Loading

0 comments on commit d2af48b

Please sign in to comment.