btcpayserver/BTCPayServer.Tests
2024-04-09 11:13:07 +09:00
..
AltcoinTests Fix flaky 2024-03-13 22:51:55 +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 Dotnet reformat 2023-04-10 11:07:03 +09:00
Mocks Register rate providers in DI, so it can be accessed by plugins (#4551) 2023-01-30 09:46:12 +09:00
Properties Modifying launchSettings.json to follow 2 space indent convention 2020-07-11 16:45:44 -05:00
TestData Fix: Old payments not showing up in reports (#5812) 2024-03-05 16:10:54 +09:00
ApiKeysTests.cs Do not through missing-permission error when no store on /api/v1/stores (Close #4735) (#4748) 2023-03-08 21:36:51 +09:00
BTCPayServer.Tests.csproj Apps: Allow authenticated, non-owner users permissioned access (#5702) 2024-01-25 21:00:33 +09:00
BTCPayServerTester.cs Admins can approve registered users (#5647) 2024-01-31 14:45:54 +09:00
ChargeTester.cs Support the new LN lib (#5422) 2023-11-21 18:55:02 +09:00
CheckoutUITests.cs Unify checkout v1 behaviour with v2 2023-04-25 11:36:45 +02:00
Checkoutv2Tests.cs Fix build warnings and flaky tests (#5780) 2024-02-22 09:38:06 +09:00
CollectionDefinitions.cs Run tests in parallel 2021-11-23 19:17:17 +09:00
CrowdfundTests.cs Crowdfund : Add Buyer information / Additional information(forms) like POS (#5659) 2024-02-21 14:41:21 +01: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-bitcoin-multisig-setup.sh Fix typos (#5529) 2023-12-02 10:13:28 +01:00
docker-compose.altcoins.yml Bumping LND to 0.17.4-beta (#5739) 2024-02-16 08:43:51 -06:00
docker-compose.yml Bumping LND to 0.17.4-beta (#5739) 2024-02-16 08:43:51 -06: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-holdinvoice.sh Refactor Payouts (#4032) 2022-08-17 09:45:51 +02:00
docker-customer-lncli.ps1 Bumping LND to 0.17.4-beta (#5739) 2024-02-16 08:43:51 -06: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.ps1 Bumping LND to 0.17.4-beta (#5739) 2024-02-16 08:43:51 -06:00
docker-merchant-lncli.sh Improve Lightning test scripts (#3435) 2022-02-10 12:25:14 +09:00
Dockerfile bump NBX 2024-01-18 17:21:15 +09:00
Extensions.cs Boltcard integration (#5419) 2023-12-06 09:17:58 +09: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 remove decimals for Colombian (COP) and Argentina's Peso (ARS) (#5710) 2024-02-02 17:16:13 +09:00
FormTests.cs Support adjusting form invoice amount by multiplier (#5463) 2023-12-01 09:10:58 +01:00
GreenfieldAPITests.cs Onboarding: Invite new users on store level (#5719) 2024-03-19 14:58:33 +01: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 Fix build warnings and flaky tests (#5780) 2024-02-22 09:38:06 +09:00
PaymentRequestTests.cs Payment Request: Add processing status for on-chain payments (#5309) 2023-09-19 10:10:13 +09:00
POSTests.cs Archive stores and apps (#5296) 2023-09-11 09:59:17 +09:00
PSBTTests.cs Remove unused variables (#5669) 2024-01-18 09:47:39 +09:00
README.md Fix typos in README file (#3644) 2022-04-18 10:24:17 +09:00
SeleniumTester.cs Onboarding: Invite new users on store level (#5719) 2024-03-19 14:58:33 +01:00
SeleniumTests.cs Template Editor: Apply item changes directly (#5849) 2024-03-19 14:59:26 +01:00
ServerTester.cs Improve checkout page load time by fetching recommended fee in the background periodically (#5672) 2024-01-18 17:16:57 +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 Onboarding: Invite new users on store level (#5719) 2024-03-19 14:58:33 +01:00
TestUtils.cs Pluginify BTCPayNetworkProvider (#5331) 2023-11-29 18:51:40 +09:00
ThirdPartyTests.cs Fix JSContent test 2024-04-09 11:13:07 +09:00
UnitTest1.cs Onboarding: Invite new users on store level (#5719) 2024-03-19 14:58:33 +01:00
UnitTestBase.cs Pluginify BTCPayNetworkProvider (#5331) 2023-11-29 18:51:40 +09:00
UtilitiesTests.cs Update languages updates from transifex (#5679) 2024-01-19 21:45:14 +09:00
Utils.cs Greenfield: Admins can create/delete API keys of any user (#4680) 2023-02-24 16:19:03 +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"