btcpayserver/BTCPayServer.Tests
Wouter Samaey 2abc35058b
Custodian Account UI: CRUD (#3923)
* WIP New APIs for dealing with custodians/exchanges

* Simplified things

* More API refinements + index.html file for quick viewing

* Finishing touches on spec

* Switched cryptoCode to paymentMethod as this allows us to differentiate between onchain and lightning

* Moved draft API docs to "/docs-draft"

* WIP baby steps

* Added DB migration for CustodianAccountData

* Rough but working POST /v1/api/custodian-account + GET /v1/api/custodian

* WIP + early Kraken API client

* Moved service registration to proper location

* Working create + list custodian accounts + permissions + WIP Kraken client

* Kraken API Balances call is working

* Added asset balances to response

* List Custodian Accounts call does not load assetBalances by default, because it can fail. Can be requested when needed.

* Call to get the details of 1 specific custodian account

* Added permissions to swagger

* Added "tradableAssetPairs" to Kraken custodian response + cache the tradable pairs in memory for 24 hours

* Removed unused file

* WIP + Moved files to better locations

* Updated docs

* Working API endpoint to get info on a trade (same response as creating a new trade)

* Working API endpoints for Deposit + Trade + untested Withdraw

* Delete custodian account

* Trading works, better error handling, cleanup

* Working withdrawals + New endpoint for getting bid/ask prices

* Completed withdrawals + new endpoint for getting info on a past withdrawal to simplify testing, Enums are output as strings,

* Better error handling when withdrawing to a wrong destination

* WithdrawalAddressName in config is now a string per currency (dictionary)

* Added TODOs

* Only show the custodian account "config" to users who are allowed

* Added the new permissions to the API Keys UI

* Renamed KrakenClient to KrakenExchange

* WIP Kraken Config Form

* Removed files for UI again, will make separate PR later

* Fixed docs + Refactored to use PaymentMethod more + Added "name" to custodian account + Using cancelationToken everywhere

* Updated withdrawal info docs

* First unit test

* Complete tests for /api/v1/custodians and /api/v1/custodian-accounts endpoints + Various improvements and fixes

* Mock custodian and more exceptions

* Many more tests + cleanup, moved files to better locations

* More tests

* WIP more tests

* Greenfield API tests complete

* Added missing "Name" column

* Cleanup, TODOs and beginning of Kraken Tests

* Added Kraken tests using public endpoints + handling of "SATS" currency

* Added 1st mocked Kraken API call: GetAssetBalancesAsync

* Added assert for bad config

* Mocked more Kraken API responses + added CreationDate to withdrawal response

* pr review club changes

* Make Kraken Custodian a plugin

* Re-added User-Agent header as it is required

* Fixed bug in market trade on Kraken using a percentage as qty

* A short delay so Kraken has the time to execute the market order and we don't fetch the details too quickly.

* Merged the draft swagger into the main swagger since it didn't work anymore

* Fixed API permissions test

* Removed 2 TODOs

* Fixed unit test

* After a utxo rescan, the cached balance should be invalidated

* Fixed Kraken plugin build issues

* Added Kraken plugin to build

* WIP UI + config form

* Create custodian account almost working - only need to add in the config form

* Working form, but lacks refinement

* Viewing balances + Editing custodian account works, but cannot change the withdrawal destination config because that is an object using a name with [] in it

* cleanup

* Minor cleanup, comments

* Working: Delete custodian account

* Moved the MockCustodian used in tests to a new plugin + linked it to the tests

* WIP viewing custodian account balances

* Split the Mock custodian into a Mock + Fake, various UI improvements and minor fixes

* Minor UI fixes

* Removed broken link

* Removed links to anchors as they cannot pass the tests since they use JavaScript

* Removed non-existing link. Even though it was commented out, the test still broke?

* Added TODOs

* Now throwing BadConfigException if API key is invalid

* UI improvements

* Commented out unfinished API endpoints. Can be finished later.

* Show fiat value for fiat assets

* Removed Kraken plugin so I can make a PR


Removed more Kraken files

* Add experimental route on UICustodianAccountsControllre

* Removed unneeded code

* Cleanup code

* Processed Nicolas' feedback

Co-authored-by: Kukks <evilkukka@gmail.com>
Co-authored-by: nicolas.dorier <nicolas.dorier@gmail.com>
2022-07-07 22:42:50 +09:00
..
AltcoinTests Dashboard: Add Point Of Sale data (#3897) 2022-06-28 14:05:02 +09:00
Lnd Test improvement exposing failing test (#3120) 2021-11-26 15:02:30 +09:00
Logging Remove Logs static singletons 2021-11-23 13:55:34 +09:00
MockCustodian Custodian Account UI: CRUD (#3923) 2022-07-07 22:42:50 +09:00
Mocks Removing unused usings, readonly fields where possible 2020-06-28 22:07:48 -05:00
Properties Modifying launchSettings.json to follow 2 space indent convention 2020-07-11 16:45:44 -05:00
TestData Isolate tests requiring internet access 2021-11-23 12:53:05 +09:00
ApiKeysTests.cs Fix empty permissions case 2022-06-29 15:36:54 +02:00
BTCPayServer.Tests.csproj Public Invoice receipt (#3612) 2022-07-06 21:14:55 +09:00
BTCPayServerTester.cs Tests should use explorer.postgres 2022-07-05 14:39:50 +09:00
ChargeTester.cs Removing unused usings, readonly fields where possible 2020-06-28 22:07:48 -05:00
CheckoutUITests.cs Redirect to invoice details instead of list upon creation (#3936) 2022-07-07 21:47:59 +09:00
CollectionDefinitions.cs Run tests in parallel 2021-11-23 19:17:17 +09:00
CrowdfundTests.cs Dashboard: Add Point Of Sale data (#3897) 2022-06-28 14:05:02 +09:00
CustomerHttpServer.cs Warning if not using 'simple using' 2022-01-14 17:50:29 +09:00
docker-bitcoin-cli.ps1 Fix all script because of docker-compose team screwing up (https://github.com/docker/compose/issues/6316) 2018-11-22 16:16:10 +09:00
docker-bitcoin-cli.sh Fix all script because of docker-compose team screwing up (https://github.com/docker/compose/issues/6316) 2018-11-22 16:16:10 +09:00
docker-bitcoin-generate.ps1 Add cmd tools to generate blocks 2019-05-08 12:19:16 +09:00
docker-bitcoin-generate.sh Fix possibly dirty generated bitcoin address 2020-10-29 14:16:23 +01:00
docker-compose.altcoins.yml Tests should use explorer.postgres 2022-07-05 14:39:50 +09:00
docker-compose.yml Tests should use explorer.postgres 2022-07-05 14:39:50 +09:00
docker-customer-lightning-cli.ps1 Fix docker-customer-lightning-cli.ps1 pay doesn't work (Fix #1509) 2020-04-27 03:59:16 +09:00
docker-customer-lightning-cli.sh Fix docker-customer-lightning-cli.ps1 pay doesn't work (Fix #1509) 2020-04-27 03:59:16 +09:00
docker-customer-lncli.sh Improve Lightning test scripts (#3435) 2022-02-10 12:25:14 +09:00
docker-elements.ps1 Decimal precision and filter valid transaction (#1538) 2020-05-04 01:04:34 +09:00
docker-entrypoint.sh Make sure dotnet test show test progress 2021-12-27 14:26:03 +09:00
docker-lightning-channel-setup.sh Improve Lightning test scripts (#3435) 2022-02-10 12:25:14 +09:00
docker-lightning-channel-teardown.sh Improve Lightning test scripts (#3435) 2022-02-10 12:25:14 +09:00
docker-litecoin-cli.ps1 Fix all script because of docker-compose team screwing up (https://github.com/docker/compose/issues/6316) 2018-11-22 16:16:10 +09:00
docker-litecoin-cli.sh Fix all script because of docker-compose team screwing up (https://github.com/docker/compose/issues/6316) 2018-11-22 16:16:10 +09:00
docker-merchant-lightning-cli.ps1 Fix docker-customer-lightning-cli.ps1 pay doesn't work (Fix #1509) 2020-04-27 03:59:16 +09:00
docker-merchant-lightning-cli.sh Fix docker-customer-lightning-cli.ps1 pay doesn't work (Fix #1509) 2020-04-27 03:59:16 +09:00
docker-merchant-lncli.sh Improve Lightning test scripts (#3435) 2022-02-10 12:25:14 +09:00
Dockerfile Migrate to .net6.0 (#3198) 2021-12-27 13:15:43 +09:00
Extensions.cs Fix selective stores case 2022-06-29 15:36:54 +02:00
FactWithSecretAttribute.cs Add third party tests to the suite, skip azure test if not configured 2021-11-23 13:26:47 +09:00
FakeServer.cs Improve tests of webhooks 2020-11-14 13:39:44 +09:00
FastTests.cs Public Invoice receipt (#3612) 2022-07-06 21:14:55 +09:00
GreenfieldAPITests.cs Custodian Account UI: CRUD (#3923) 2022-07-07 22:42:50 +09:00
LanguageServiceTests.cs Warning if not using 'simple using' 2022-01-14 17:50:29 +09:00
LightningDTester.cs Removing unused usings, readonly fields where possible 2020-06-28 22:07:48 -05:00
MockDelay.cs Removing unused usings, readonly fields where possible 2020-06-28 22:07:48 -05:00
PayJoinTests.cs Remove debug line in selenium tests 2022-02-21 16:17:36 +09:00
PaymentRequestTests.cs Warning if not using 'simple using' 2022-01-14 17:50:29 +09:00
POSTests.cs Dashboard: Add Point Of Sale data (#3897) 2022-06-28 14:05:02 +09:00
PSBTTests.cs Remove debug line in selenium tests 2022-02-21 16:17:36 +09:00
README.md Fix typos in README file (#3644) 2022-04-18 10:24:17 +09:00
SeleniumTester.cs Public Invoice receipt (#3612) 2022-07-06 21:14:55 +09:00
SeleniumTests.cs Redirect to invoice details instead of list upon creation (#3936) 2022-07-07 21:47:59 +09:00
ServerTester.cs Tests should use explorer.postgres 2022-07-05 14:39:50 +09:00
sshd.Dockerfile Add sshd service so we can test SSH stuff as well 2019-09-06 16:51:49 +09:00
TestAccount.cs Refactoring: Extract ITempDataDictionary extensions 2022-03-08 08:17:39 +00:00
TestUtils.cs Support LNURL Auth 2022-01-14 13:26:30 +01:00
ThirdPartyTests.cs fix test 2022-06-09 12:43:28 +02:00
UnitTest1.cs Dashboard: Add Point Of Sale data (#3897) 2022-06-28 14:05:02 +09:00
UnitTestBase.cs Remove Logs static singletons 2021-11-23 13:55:34 +09:00
UtilitiesTests.cs Add third party tests to the suite, skip azure test if not configured 2021-11-23 13:26:47 +09:00
Utils.cs Warning if not using 'simple using' 2022-01-14 17:50:29 +09:00
xunit.runner.json Run tests in parallel 2021-11-23 19:17:17 +09:00

Tooling

This README describe some useful tooling that you may need during development and testing. To learn how to get started with your local development environment, read our documentation.

How to manually test payments

Using the test bitcoin-cli

You can call bitcoin-cli inside the container with docker exec. For example, if you want to send 0.23111090 to mohu16LH66ptoWGEL1GtP6KHTBJYXMWhEf:

./docker-bitcoin-cli.sh sendtoaddress "mohu16LH66ptoWGEL1GtP6KHTBJYXMWhEf" 0.23111090

If you are using Powershell:

.\docker-bitcoin-cli.ps1 sendtoaddress "mohu16LH66ptoWGEL1GtP6KHTBJYXMWhEf" 0.23111090

You can also generate blocks:

.\docker-bitcoin-generate.ps1 3

Using Polar to test Lightning payments

  • Install and run Polar. Setup a small network of nodes.
  • Go to your store's General Settings and enable Lightning.
  • Build your connection string using the Connect information in the Polar app.

LND Connection string example: type=lnd-rest;server=https://127.0.0.1:8084/;macaroonfilepath="local path to admin.macaroon on your computer, without these quotes";allowinsecure=true

Now you can create a Lightning invoice on BTCPay Server regtest and make a payment through Polar.

PLEASE NOTE: You may get an exception break in Visual Studio. You must quickly click "Continue" in VS so the invoice is generated. Or, uncheck the box that says, "Break when this exception type is thrown".

Using the test litecoin-cli

Same as bitcoin-cli, but with .\docker-litecoin-cli.ps1 and .\docker-litecoin-cli.sh instead.

Using the test lightning-cli

If you are using Linux:

./docker-customer-lightning-cli.sh pay lnbcrt100u1pd2e6uspp5ajnadvhazjrz55twd5k6yeg9u87wpw0q2fdr7g960yl5asv5fmnqdq9d3hkccqpxmedyrk0ehw5ueqx5e0r4qrrv74cewddfcvsxaawqz7634cmjj39sqwy5tvhz0hasktkk6t9pqfdh3edmf3z09zst5y7khv3rvxh8ctqqw6mwhh

If you are using Powershell:

.\docker-customer-lightning-cli.ps1 pay lnbcrt100u1pd2e6uspp5ajnadvhazjrz55twd5k6yeg9u87wpw0q2fdr7g960yl5asv5fmnqdq9d3hkccqpxmedyrk0ehw5ueqx5e0r4qrrv74cewddfcvsxaawqz7634cmjj39sqwy5tvhz0hasktkk6t9pqfdh3edmf3z09zst5y7khv3rvxh8ctqqw6mwhh

If you get this message:

{ "code" : 205, "message" : "Could not find a route", "data" : { "getroute_tries" : 1, "sendpay_tries" : 0 } }

Please, run the test CanSetLightningServer, this will establish a channel between the customer and the merchant, then, retry.

Alternatively you can run the ./docker-lightning-channel-setup.sh script to establish the channel connection. The ./docker-lightning-channel-teardown.sh script closes any existing lightning channels.

Alternative Lightning testing: Using Polar to test Lightning payments

  • Install and run Polar. Setup a small network of nodes.
  • Go to your store's General Settings and enable Lightning.
  • Build your connection string using the Connect information in the Polar app.

LND Connection string example: type=lnd-rest;server=https://127.0.0.1:8084/;macaroonfilepath="local path to admin.macaroon on your computer, without these quotes";allowinsecure=true

Now you can create a lightning invoice on BTCPay Server regtest and make a payment through Polar.

PLEASE NOTE: You may get an exception break in Visual Studio. You must quickly click "Continue" in VS so the invoice is generated. Or, uncheck the box that says, "Break when this exception type is thrown".

FAQ

docker-compose up dev failed or tests are not passing, what should I do?

  1. Run docker-compose down --volumes (this will reset your test environment)
  2. Run docker-compose pull (this will ensure you have the latest images)
  3. Run again with docker-compose up dev

How to run the Altcoin environment?

docker-compose -f docker-compose.altcoins.yml up dev

If you still have issues, try to restart docker.

How to run the Selenium test with a browser?

Run dotnet user-secrets set RunSeleniumInBrowser true to run tests in browser.

To switch back to headless mode (recommended) you can run dotnet user-secrets remove RunSeleniumInBrowser.

Session not created: This version of ChromeDriver only supports Chrome version 88

When you run tests for selenium, you may end up with this error. This happen when we update the selenium packages on BTCPay Server while you did not update your chrome version.

If you want to use a older chrome driver on this page then point to it with

dotnet user-secrets set ChromeDriverDirectory "path/to/the/driver/directory"