Rusty Russell
b460590278
plugins: detect and fixup old relative paths.
...
Note that we move adding the plugin to the plugins list to the end, otherwise
the hook from logging can examine the (uninitialized) plugin.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-08-03 09:10:11 +00:00
Rusty Russell
4fcd94a091
pytest: use absolute paths for plugin arguments.
...
We're going to change this in the next patch.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-08-03 09:10:11 +00:00
trueptolemy
5ac02907bb
pytest: Add the test for 'forward_event' in test_plugin
2019-08-01 18:49:25 +08:00
Rusty Russell
79d32ec2f2
plugin: notice when plugin has *started* configuring.
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-07-30 08:44:01 +08:00
Rusty Russell
df8a6f615b
pytest: test for crash when we do a plugin op and a plugin has not finished init
...
We try to start it twice, with predictable hilarious results:
DEBUG plugin-manager started(20701) /home/rusty/devel/cvs/lightning/tests/plugins/slow_init.py
DEBUG lightningd(20670): Adding block 101: 0f26301caaae390d1b956c3eb73827d1f87a2af306561348045bf1313b7551b0
INFO plugin-slow_init.py slow_init.py initializing
DEBUG plugin-manager started(20704) /home/rusty/devel/cvs/lightning/tests/plugins/slow_init.py
**BROKEN** lightningd(20670): FATAL SIGNAL 6 (version v0.7.1-146-g7d3b352-modded)
**BROKEN** lightningd(20670): backtrace: common/daemon.c:45 (send_backtrace) 0x55a29c3ec539
**BROKEN** lightningd(20670): backtrace: common/daemon.c:53 (crashdump) 0x55a29c3ec589
**BROKEN** lightningd(20670): backtrace: (null):0 ((null)) 0x7fa281ebcf5f
**BROKEN** lightningd(20670): backtrace: (null):0 ((null)) 0x7fa281ebced7
**BROKEN** lightningd(20670): backtrace: (null):0 ((null)) 0x7fa281e9e534
**BROKEN** lightningd(20670): backtrace: (null):0 ((null)) 0x7fa281e9e40e
**BROKEN** lightningd(20670): backtrace: (null):0 ((null)) 0x7fa281eae011
**BROKEN** lightningd(20670): backtrace: lightningd/json_stream.c:225 (json_stream_output_) 0x55a29c3bff5f
**BROKEN** lightningd(20670): backtrace: lightningd/plugin.c:383 (plugin_write_json) 0x55a29c3e103f
**BROKEN** lightningd(20670): backtrace: ccan/ccan/io/io.c:59 (next_plan) 0x55a29c43316b
**BROKEN** lightningd(20670): backtrace: ccan/ccan/io/io.c:435 (io_do_always) 0x55a29c433df1
**BROKEN** lightningd(20670): backtrace: ccan/ccan/io/poll.c:300 (handle_always) 0x55a29c435865
**BROKEN** lightningd(20670): backtrace: ccan/ccan/io/poll.c:377 (io_loop) 0x55a29c435b3d
**BROKEN** lightningd(20670): backtrace: lightningd/io_loop_with_timers.c:24 (io_loop_with_timers) 0x55a29c3bdfcf
**BROKEN** lightningd(20670): backtrace: lightningd/lightningd.c:830 (main) 0x55a29c3c44b6
**BROKEN** lightningd(20670): backtrace: (null):0 ((null)) 0x7fa281e9fb6a
**BROKEN** lightningd(20670): backtrace: (null):0 ((null)) 0x55a29c3ac0f9
**BROKEN** lightningd(20670): backtrace: (null):0 ((null)) 0xffffffffffffffff
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-07-30 08:44:01 +08:00
darosior
307fb0708e
lightningd/plugin_control: don't control non-dynamic plugins
2019-07-28 07:24:04 +00:00
darosior
9ddc2e0334
Add the 'plugin' subcommands to pylightning and add a test for them
2019-07-28 07:24:04 +00:00
darosior
2683170da8
Test and document 'channel_opened' notification
2019-07-27 12:18:25 +02:00
darosior
34533ead68
Plugins: Add a test for the 'invoice_payment' notfication
2019-07-25 11:19:47 +08:00
Christian Decker
53488e5739
pytest: Strengthen the htlc_accepted tests
...
We were having a few issues with malformed data in the past, so this time we
really check that stuff.
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2019-07-13 14:44:12 +02:00
Rusty Russell
54ce4ed1cf
pytest: fail tests if we get any LOG_BROKEN level messages, unless flagged.
...
And clean up some dev ones which actually happen (mainly by calling
channel_fail_permanent which logs UNUSUAL, rather than
channel_internal_error which logs BROKEN).
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-07-02 03:26:10 +00:00
Rusty Russell
5f02294b5b
lightningd/log: prefix log messages with level.
...
In particular, this lets us spot UNUSUAL and BROKEN messages easily.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-07-02 03:26:10 +00:00
Rusty Russell
380c044668
tests: add plugin for simple invoice delay.
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-06-11 23:19:11 +00:00
trueptolemy
4d08ed2fa6
pytest: Add a test for the 'warning' subscription and notification
...
1. Create a plugin: ./lightning/tests/plugins/pretend_badlog.py
This plugin subscribes 'warning' notification and log the payload of
'warning';
2. Add a new test: tests/test_plugin.py::test_warning_notification
This test runs the plugin-pretend_badlog.py and check if 'warning'
notification can be normal triggered and subscribed.
2019-06-07 01:23:51 +00:00
Michael Schmoock
c40250ad0b
test: adds wait mempool to flaky tests
2019-06-06 00:04:59 +00:00
Christian Decker
dd26a01c54
pytest: Add a test for htlc_accepted hook replay on startup
2019-06-04 00:27:15 +00:00
Christian Decker
9fd8be6463
pytest: Add tests for htlc_accepted_hook
...
Two tests: one for failures and one for in-path resolution.
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2019-06-04 00:27:15 +00:00
Christian Decker
b54577041a
pytest: Add a simple test for the hooks
...
This uses the `htlc_accepted` hook to delay payment acceptance.
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2019-06-04 00:27:15 +00:00
Michael Schmoock
107381aca2
test: fix flakyness of funding_reorg_private openchannel_hook
2019-06-03 19:30:19 +02:00
Christian Decker
ced2ff8aa7
pytest: Mark repeat offenders as flaky
...
It's always the same few tests that fail, so I'm marking them as flaky and
will do a cleanup round later to individually address them.
I've been tracking the failures on the master branch for a few months now and
these are the worst offenders:
|-----------------------------------------|--------|--------|-------|
| test_name | state | branch | count |
|-----------------------------------------|--------|--------|-------|
| test_pay_direct | FAILED | master | 31 |
| test_reconnect_gossiping | FAILED | master | 20 |
| test_htlc_send_timeout | FAILED | master | 15 |
| test_pay_limits | FAILED | master | 13 |
| test_permfail | FAILED | master | 13 |
| test_funding_reorg_private | FAILED | master | 12 |
| test_invoice | FAILED | master | 12 |
| test_invoice_preimage | FAILED | master | 12 |
| test_shutdown | FAILED | master | 12 |
| test_withdraw | FAILED | master | 12 |
| test_gossip_store_load_v3 | FAILED | master | 11 |
| test_onchain_multihtlc_their_unilateral | FAILED | master | 10 |
| test_opening_tiny_channel | FAILED | master | 10 |
| test_channel_reenable | FAILED | master | 9 |
| test_crashlog | FAILED | master | 9 |
| test_gossip_weirdalias | FAILED | master | 9 |
| test_invoice_expiry | FAILED | master | 9 |
| test_onchain_multihtlc_our_unilateral | FAILED | master | 9 |
| test_peerinfo | FAILED | master | 9 |
| test_private_channel | FAILED | master | 9 |
| test_shutdown_reconnect | FAILED | master | 9 |
| test_closing | FAILED | master | 8 |
| test_closing_different_fees | FAILED | master | 8 |
| test_closing_while_disconnected | FAILED | master | 8 |
| test_gossip_timestamp_filter | FAILED | master | 8 |
| test_gossipwith | FAILED | master | 8 |
| test_invoice_routeboost | FAILED | master | 8 |
| test_onchain_middleman | FAILED | master | 8 |
| test_plugin_notifications | FAILED | master | 8 |
| test_reconnect_channel_peers | FAILED | master | 8 |
| test_bad_onion | FAILED | master | 7 |
| test_closing_torture | FAILED | master | 7 |
| test_fulfill_incoming_first | FAILED | master | 7 |
| test_funding_reorg_disagree_scid_route | FAILED | master | 7 |
| test_pay_disconnect | FAILED | master | 7 |
| test_balance | FAILED | master | 6 |
| test_check_command | FAILED | master | 6 |
| test_closing_id | FAILED | master | 6 |
| test_gossip_addresses | FAILED | master | 6 |
| test_gossip_notices_close | FAILED | master | 6 |
| test_setchannelfee_usage | FAILED | master | 6 |
| test_announce_address | FAILED | master | 5 |
| test_connect_by_gossip | FAILED | master | 5 |
| test_gossip_badsig | FAILED | master | 5 |
| test_gossip_disable_channels | FAILED | master | 5 |
| test_gossip_jsonrpc | FAILED | master | 5 |
| test_gossip_persistence | FAILED | master | 5 |
| test_gossip_pruning | FAILED | master | 5 |
| test_onchain_different_fees | FAILED | master | 5 |
| test_onchain_dust_out | FAILED | master | 5 |
|-----------------------------------------|--------|--------|-------|
2019-05-26 16:19:10 +02:00
Rusty Russell
e5b5f1d7e5
openingd: add openchannel hook.
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-05-20 20:31:07 -04:00
Christian Decker
c96cc8a444
pytest: Fix the flaky test_plugin_connected_hook test
...
It was a bit eager :-)
Signed-off-by: Christian Decker <@cdecker>
2019-04-30 17:56:09 -05:00
Rusty Russell
7f7ad4f89f
connected_hook: allow hook to specify an error message.
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-04-23 15:26:42 +02:00
Rusty Russell
9c373fecb6
pytest: test the invoice hook.
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-04-12 03:32:48 +00:00
Rusty Russell
5009d628a3
lightning-cli: do pretty-printing.
...
Plugins don't do it right anyway, and we're about to remove it from
lightningd. Produces same format as json_pp.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-04-09 12:37:16 -07:00
Rusty Russell
7ccf3af51d
pytest: test the db hook plugin.
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-04-08 01:56:17 +00:00
Rusty Russell
cc342fda83
pylightning: make sure UTF-8 gets passed intact.
...
1. We need to read in as a byte string, then decode into utf8 once we
have a marker. Otherwise we seem to mangle it horribly, and we
might have a bad utf8 string anyway.
2. We need to suppress the JSON \u escapes on output.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-03-05 11:43:22 +01:00
Rusty Russell
5f437de771
pytest: test passing utf8 into and out of plugin JSON.
...
We should be able to pass UTF-8 strings to and from plugins without
python turning them into JSON-\u escapes.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-03-05 11:43:22 +01:00
Rusty Russell
6e63d79159
pylightning: translate msat input to class Millisatoshi
...
Rather than using LightningJSONDecoder's implicit "field name and
value ends in msat, try converting to Millisatoshi", we do it to
parameters using type annotations.
If you had a parameter which was an array or dict itself, we don't
delve into that, but that's probably OK.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-02-25 21:45:21 +00:00
Rusty Russell
c7316d7ba2
pytest: test that we translate to and from Millisatoshi on plugin RPC.
...
We don't, but we should, like we do for normal RPC. However, I chose
to use function annotations, rather than names-ending-in-'msat'
because it's more Pythony.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-02-25 21:45:21 +00:00
Rusty Russell
1ec959752b
plugin/pay: rename 'description' to 'label', deprecate 'description'.
...
This is the same deprecation, but one level up. For the moment, we
still support invoices with a `h` field (where description will be
necessary) but that will be removed once this option is removed.
Note that I just changed pylightning without backwards compatibility,
since the field was unlikely to be used, but we could do something
more complex here?
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-02-23 05:45:25 +00:00
Christian Decker
571fb44d20
pylightning: Add a small test for async rpcmethods
...
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2019-02-22 02:59:36 +00:00
Christian Decker
5d9d5ceed1
pytest: Test the new peer_connected hook with a reject plugin
...
This plugin just rejects `node_id`s it gets told about.
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2019-02-20 15:37:59 +01:00
Rusty Russell
53c0a21d2c
plugins: get usage from plugins (required unless deprecated_apis == True).
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-02-07 20:33:50 +00:00
Rusty Russell
ba8a9d1fde
libplugin: quick fix for bad JSON produced by plugins on bad paramters.
...
Internally libplugin turns ' into ", which causes these messages to produce
bad JSON.
The real fix is to remove the '->" convenience substitution and port the
JSON creation APIs into common/ from lightningd/
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-01-21 11:20:11 +01:00
Rusty Russell
0a8b4f8935
pay: remove inbuilt command in favor of plugin.
...
This doesn't actually remove some of the now-unnecessary infrastructure
though.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-01-17 13:02:24 +01:00
Rusty Russell
ad1e1bd528
plugins: minimal 'pay' plugin.
...
I wrote this sync first, then rewrote async, then developed libplugin.
But committing all that just wastes reviewer time, so I present it as
if it was always asnc and using the library helper.
Currently the command it registers is 'pay2', but when it's complete
we'll remove the internal 'pay' and rename it. This does a single
'getroute/sendpay' call. No retries, no options.
Shockingly, this by itself is almost sufficient to pass our current test
suite with `pay`->`pay2`.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-01-17 13:02:24 +01:00
Rusty Russell
61420bf79b
configure: (mostly) revert b7a56f0531
...
Plugins are a first-class citizen again.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-01-15 02:52:13 +00:00
Christian Decker
b7a56f0531
plugin: Gate the plugin subsystem with the --enable-plugins configure flag
...
Since we are planning to release a bug fix release, and the plugin
subsystem is not yet complete, it is better to make plugin support
opt-in while we continue testing.
Signed-off-by: Christian Decker <decker.christian@gmail.com>
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-01-10 17:15:10 -08:00
Christian Decker
25ca49c444
pytest: Add a test for the event subscription and notification
...
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2018-12-30 14:36:02 +01:00
Christian Decker
643480cfd8
pylightning: Migrate the test plugin to use the new wrapper
...
Should be a lot easier to see what happens :-)
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2018-12-15 15:04:32 +01:00
Christian Decker
a304db9be2
plugin: Handle log notifications from plugins
...
Logs are parsed and injected into the main daemon's logs.
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2018-12-13 02:36:43 +00:00
Christian Decker
f5a3f1f0a2
plugin: Add a test for timeout and broken manifest
...
Both of these plugins will fail in interesting ways, and we should
still handle them correctly.
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2018-12-05 23:15:59 +00:00
Rusty Russell
eb03b33655
plugins: add and install built-in plugin dir, add clear and disable options.
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2018-12-05 01:22:55 +01:00
Rusty Russell
a4287f99fd
lightningd: add --plugin-dir option to load directory full of plugins.
...
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2018-12-05 01:22:55 +01:00
Christian Decker
1d75a70995
pytest: Add a test for the JSON-RPC passthrough
...
Tests JSON-RPC registration, as well as success and failures.
Signed-off-by: Christian Decker <decker.christian@gmail.com>
2018-12-02 22:55:47 +00:00
Christian Decker
879f9b7986
plugin: Make a common directory of plugins in contrib
...
No need to create a directory each.
Signed-off-by: Christian Decker <@cdecker>
2018-11-26 22:53:37 +00:00
Christian Decker
e27b2ea69b
pytest: Add a test for the plugin option passthrough
...
Signed-off-by: Christian Decker <@cdecker>
2018-11-26 22:53:37 +00:00