ed7031981b
* Swap bootstrap asset files * Update themes and color definitions * Move general bootstrap customizations * Theme updates Theme updates * Remove BuildBundlerMinifier This lead to an error, because BuildBundlerMinifier and BundlerMinifier.Core seem to conflict here. Details: https://stackoverflow.com/a/61119586 * Rewplace btn-block class with w-100 * Update badge classes * Remove old font family head variable * Update margin classes * Cleanups * Update float classes * Update text classes * Update padding classes * Update border classes * UPdate dropdown classes * Update select classes * Update neutral custom props * Update bootstrap and customizations * Update ChromeDriver; disable smooth scroll https://github.com/SeleniumHQ/selenium/issues/8295 * Improve alert messages * Improve bootstrap customizations * Disable reduced motion See also 7358282f * Update Bootstrap data attributes * Update file inputs * Update input groups * Replace deprecated jumbotron class * Update variables; re-add negative margin util classes * Update cards * Update form labels * Debug alerts * Fix aria-labelledby associations * Dropdown-related test fixes * Fix CanUseWebhooks test * Test fixes * Nav updates * Fix nav usage in wallet send and payouts * Update alert and modal close buttons * Re-add backdrop properties * Upgrade Bootstrap to v5 final * Update screen reader classes * Update font-weight classes * Update monospace font classes * Update accordians * Update close icon usage * Cleanup * Update scripts and style integrations * Update input group texts * Update LN node setup page * Update more form control classes * Update inline forms * Add js specific test * Upgrade Vue.js * Remove unused JS * Upgrade Bootstrap to v5.0.1 * Try container related test updates * Separate jQuery bundle * Remove jQuery from LND seed backup page * Remove unused code * Refactor email autofill js * Refactor camera scanner JS * Re-add tests * Re-add BuildBundlerMinifier * Do not minify bundles containing Bootstrap Details https://github.com/madskristensen/BundlerMinifier/issues/558 * Update bundles * Cleanup JS test * Cleanup tests involving dropdowns * Cleanup tests involving collapses * Cleanup locale additions in ConfigureCore * Cleanup bundles * Remove duplicate status message * Cleanup formatting * Fix missing validation scripts * Remove unused unminified Bootstrap js files * Fix classic theme * Fix Casa theme * Fix PoS validation |
||
---|---|---|
.. | ||
AltcoinTests | ||
Lnd | ||
Logging | ||
Mocks | ||
Properties | ||
TestData | ||
ApiKeysTests.cs | ||
BTCPayServer.Tests.csproj | ||
BTCPayServerTester.cs | ||
ChargeTester.cs | ||
CheckoutUITests.cs | ||
CrowdfundTests.cs | ||
CustomerHttpServer.cs | ||
docker-bitcoin-cli.ps1 | ||
docker-bitcoin-cli.sh | ||
docker-bitcoin-generate.ps1 | ||
docker-bitcoin-generate.sh | ||
docker-compose.altcoins.yml | ||
docker-compose.yml | ||
docker-customer-lightning-cli.ps1 | ||
docker-customer-lightning-cli.sh | ||
docker-elements.ps1 | ||
docker-entrypoint.sh | ||
docker-lightning-channel-setup.sh | ||
docker-lightning-channel-teardown.sh | ||
docker-litecoin-cli.ps1 | ||
docker-litecoin-cli.sh | ||
docker-merchant-lightning-cli.ps1 | ||
docker-merchant-lightning-cli.sh | ||
Dockerfile | ||
Extensions.cs | ||
FakeServer.cs | ||
GreenfieldAPITests.cs | ||
LightningDTester.cs | ||
MockDelay.cs | ||
PayJoinTests.cs | ||
PaymentRequestTests.cs | ||
ProcessLauncher.cs | ||
PSBTTests.cs | ||
RateRulesTest.cs | ||
README.md | ||
SeleniumTester.cs | ||
SeleniumTests.cs | ||
ServerTester.cs | ||
sshd.Dockerfile | ||
StorageTests.cs | ||
TestAccount.cs | ||
TestUtils.cs | ||
UnitTest1.cs | ||
UtilitiesTests.cs | ||
Utils.cs | ||
xunit.runner.json |
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 infomation 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 exceptiontype 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?
- Run
docker-compose down --v
(this will reset your test environment) - Run
docker-compose pull
(this will ensure you have the lastest images) - 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"