2018-07-16 13:14:57 +01:00
|
|
|
.. highlight:: kotlin
|
|
|
|
.. raw:: html
|
|
|
|
|
|
|
|
<script type="text/javascript" src="_static/jquery.js"></script>
|
|
|
|
<script type="text/javascript" src="_static/codesets.js"></script>
|
|
|
|
|
2017-01-06 11:05:37 +00:00
|
|
|
Integration testing
|
|
|
|
===================
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-07-16 13:14:57 +01:00
|
|
|
Integration testing involves bringing up nodes locally and testing invariants about them by starting flows and inspecting
|
|
|
|
their state.
|
|
|
|
|
|
|
|
In this tutorial we will bring up three nodes - Alice, Bob and a notary. Alice will issue cash to Bob, then Bob will send
|
|
|
|
this cash back to Alice. We will see how to test some simple deterministic and nondeterministic invariants in the meantime.
|
|
|
|
|
|
|
|
.. note:: This example where Alice is self-issuing cash is purely for demonstration purposes, in reality, cash would be
|
|
|
|
issued by a bank and subsequently passed around.
|
|
|
|
|
|
|
|
In order to spawn nodes we will use the Driver DSL. This DSL allows one to start up node processes from code. It creates
|
|
|
|
a local network where all the nodes see each other and provides safe shutting down of nodes in the background.
|
|
|
|
|
|
|
|
.. container:: codeset
|
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/kotlin/net/corda/docs/kotlin/tutorial/test/KotlinIntegrationTestingTutorial.kt
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: kotlin
|
|
|
|
:start-after: START 1
|
|
|
|
:end-before: END 1
|
|
|
|
:dedent: 8
|
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/java/net/corda/docs/java/tutorial/test/JavaIntegrationTestingTutorial.java
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: java
|
|
|
|
:start-after: START 1
|
|
|
|
:end-before: END 1
|
|
|
|
:dedent: 8
|
|
|
|
|
|
|
|
The above code starts two nodes:
|
|
|
|
|
|
|
|
* Alice, configured with an RPC user who has permissions to start the ``CashIssueAndPaymentFlow`` flow on it and query
|
|
|
|
Alice's vault.
|
|
|
|
* Bob, configured with an RPC user who only has permissions to start the ``CashPaymentFlow`` and query Bob's vault.
|
|
|
|
|
|
|
|
.. note:: You will notice that we did not start a notary. This is done automatically for us by the driver - it creates
|
|
|
|
a notary node with the name ``DUMMY_NOTARY_NAME`` which is visible to both nodes. If you wish to customise this, for
|
|
|
|
example create more notaries, then specify the ``DriverParameters.notarySpecs`` parameter.
|
|
|
|
|
|
|
|
The ``startNode`` function returns a ``CordaFuture`` object that completes once the node is fully started and visible on
|
|
|
|
the local network. Returning a future allows starting of the nodes to be parallel. We wait on these futures as we need
|
|
|
|
the information returned; their respective ``NodeHandles`` s.
|
|
|
|
|
|
|
|
.. container:: codeset
|
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/kotlin/net/corda/docs/kotlin/tutorial/test/KotlinIntegrationTestingTutorial.kt
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: kotlin
|
|
|
|
:start-after: START 2
|
|
|
|
:end-before: END 2
|
|
|
|
:dedent: 12
|
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/java/net/corda/docs/java/tutorial/test/JavaIntegrationTestingTutorial.java
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: java
|
|
|
|
:start-after: START 2
|
|
|
|
:end-before: END 2
|
|
|
|
:dedent: 16
|
|
|
|
|
|
|
|
Next we connect to Alice and Bob from the test process using the test users we created. We establish RPC links that allow
|
|
|
|
us to start flows and query state.
|
|
|
|
|
|
|
|
.. container:: codeset
|
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/kotlin/net/corda/docs/kotlin/tutorial/test/KotlinIntegrationTestingTutorial.kt
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: kotlin
|
|
|
|
:start-after: START 3
|
|
|
|
:end-before: END 3
|
|
|
|
:dedent: 12
|
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/java/net/corda/docs/java/tutorial/test/JavaIntegrationTestingTutorial.java
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: java
|
|
|
|
:start-after: START 3
|
|
|
|
:end-before: END 3
|
|
|
|
:dedent: 16
|
|
|
|
|
|
|
|
We will be interested in changes to Alice's and Bob's vault, so we query a stream of vault updates from each.
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2017-10-01 23:33:15 +01:00
|
|
|
Now that we're all set up we can finally get some cash action going!
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-07-16 13:14:57 +01:00
|
|
|
.. container:: codeset
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/kotlin/net/corda/docs/kotlin/tutorial/test/KotlinIntegrationTestingTutorial.kt
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: kotlin
|
|
|
|
:start-after: START 4
|
|
|
|
:end-before: END 4
|
|
|
|
:dedent: 12
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/java/net/corda/docs/java/tutorial/test/JavaIntegrationTestingTutorial.java
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: java
|
|
|
|
:start-after: START 4
|
|
|
|
:end-before: END 4
|
|
|
|
:dedent: 16
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-07-16 13:14:57 +01:00
|
|
|
We start a ``CashIssueAndPaymentFlow`` flow on the Alice node. We specify that we want Alice to self-issue $1000 which is
|
|
|
|
to be payed to Bob. We specify the default notary identity created by the driver as the notary responsible for notarising
|
|
|
|
the created states. Note that no notarisation will occur yet as we're not spending any states, only creating new ones on
|
|
|
|
the ledger.
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-07-16 13:14:57 +01:00
|
|
|
We expect a single update to Bob's vault when it receives the $1000 from Alice. This is what the ``expectEvents`` call
|
|
|
|
is asserting.
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-07-16 13:14:57 +01:00
|
|
|
.. container:: codeset
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/kotlin/net/corda/docs/kotlin/tutorial/test/KotlinIntegrationTestingTutorial.kt
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: kotlin
|
|
|
|
:start-after: START 5
|
|
|
|
:end-before: END 5
|
|
|
|
:dedent: 12
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
.. literalinclude:: example-code/src/integration-test/java/net/corda/docs/java/tutorial/test/JavaIntegrationTestingTutorial.java
|
2018-07-16 13:14:57 +01:00
|
|
|
:language: java
|
|
|
|
:start-after: START 5
|
|
|
|
:end-before: END 5
|
|
|
|
:dedent: 16
|
|
|
|
|
|
|
|
Next we want Bob to send this cash back to Alice.
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-07-16 13:14:57 +01:00
|
|
|
That's it! We saw how to start up several corda nodes locally, how to connect to them, and how to test some simple invariants
|
|
|
|
about ``CashIssueAndPaymentFlow`` and ``CashPaymentFlow``.
|
2016-11-25 15:26:00 +00:00
|
|
|
|
2018-11-14 14:16:22 +00:00
|
|
|
You can find the complete test at ``example-code/src/integration-test/java/net/corda/docs/java/tutorial/test/JavaIntegrationTestingTutorial.java``
|
|
|
|
(Java) and ``example-code/src/integration-test/kotlin/net/corda/docs/kotlin/tutorial/test/KotlinIntegrationTestingTutorial.kt`` (Kotlin) in the
|
2018-07-16 13:14:57 +01:00
|
|
|
`Corda repo <https://github.com/corda/corda>`_.
|
2019-03-12 10:25:39 +00:00
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
|
|
To make sure the driver classes are included in your project you will need the following in your ``build.gradle`` file in the module in
|
|
|
|
which you want to test:
|
|
|
|
|
|
|
|
.. sourcecode:: groovy
|
|
|
|
|
|
|
|
testCompile "$corda_release_group:corda-node-driver:$corda_release_version"
|