netann: add bool param to chan_status_manager_test

Add boolean parameter for test functions without changing any
existing functionality. All current tests set manual = false, but
Future tests can set manual = true to test manual requests to
update channel state.
This commit is contained in:
Elliott Jin 2021-02-16 00:56:37 -08:00
parent 542c89ad5d
commit dbabc2e696

@ -405,30 +405,36 @@ func (h *testHarness) markInactive(channels []*channeldb.OpenChannel) {
// assertEnables requests enables for all of the passed channels, and asserts // assertEnables requests enables for all of the passed channels, and asserts
// that the errors returned from RequestEnable matches expErr. // that the errors returned from RequestEnable matches expErr.
func (h *testHarness) assertEnables(channels []*channeldb.OpenChannel, expErr error) { func (h *testHarness) assertEnables(channels []*channeldb.OpenChannel, expErr error,
manual bool) {
h.t.Helper() h.t.Helper()
for _, channel := range channels { for _, channel := range channels {
h.assertEnable(channel.FundingOutpoint, expErr) h.assertEnable(channel.FundingOutpoint, expErr, manual)
} }
} }
// assertDisables requests disables for all of the passed channels, and asserts // assertDisables requests disables for all of the passed channels, and asserts
// that the errors returned from RequestDisable matches expErr. // that the errors returned from RequestDisable matches expErr.
func (h *testHarness) assertDisables(channels []*channeldb.OpenChannel, expErr error) { func (h *testHarness) assertDisables(channels []*channeldb.OpenChannel, expErr error,
manual bool) {
h.t.Helper() h.t.Helper()
for _, channel := range channels { for _, channel := range channels {
h.assertDisable(channel.FundingOutpoint, expErr) h.assertDisable(channel.FundingOutpoint, expErr, manual)
} }
} }
// assertEnable requests an enable for the given outpoint, and asserts that the // assertEnable requests an enable for the given outpoint, and asserts that the
// returned error matches expErr. // returned error matches expErr.
func (h *testHarness) assertEnable(outpoint wire.OutPoint, expErr error) { func (h *testHarness) assertEnable(outpoint wire.OutPoint, expErr error,
manual bool) {
h.t.Helper() h.t.Helper()
err := h.mgr.RequestEnable(outpoint, false) err := h.mgr.RequestEnable(outpoint, manual)
if err != expErr { if err != expErr {
h.t.Fatalf("expected enable error: %v, got %v", expErr, err) h.t.Fatalf("expected enable error: %v, got %v", expErr, err)
} }
@ -436,10 +442,12 @@ func (h *testHarness) assertEnable(outpoint wire.OutPoint, expErr error) {
// assertDisable requests a disable for the given outpoint, and asserts that the // assertDisable requests a disable for the given outpoint, and asserts that the
// returned error matches expErr. // returned error matches expErr.
func (h *testHarness) assertDisable(outpoint wire.OutPoint, expErr error) { func (h *testHarness) assertDisable(outpoint wire.OutPoint, expErr error,
manual bool) {
h.t.Helper() h.t.Helper()
err := h.mgr.RequestDisable(outpoint, false) err := h.mgr.RequestDisable(outpoint, manual)
if err != expErr { if err != expErr {
h.t.Fatalf("expected disable error: %v, got %v", expErr, err) h.t.Fatalf("expected disable error: %v, got %v", expErr, err)
} }
@ -548,7 +556,7 @@ var stateMachineTests = []stateMachineTest{
startEnabled: false, startEnabled: false,
fn: func(h testHarness) { fn: func(h testHarness) {
// Request enables for all channels. // Request enables for all channels.
h.assertEnables(h.graph.chans(), nil) h.assertEnables(h.graph.chans(), nil, false)
// Expect to see them all enabled on the network. // Expect to see them all enabled on the network.
h.assertUpdates( h.assertUpdates(
h.graph.chans(), true, h.safeDisableTimeout, h.graph.chans(), true, h.safeDisableTimeout,
@ -561,7 +569,7 @@ var stateMachineTests = []stateMachineTest{
startEnabled: true, startEnabled: true,
fn: func(h testHarness) { fn: func(h testHarness) {
// Request disables for all channels. // Request disables for all channels.
h.assertDisables(h.graph.chans(), nil) h.assertDisables(h.graph.chans(), nil, false)
// Expect to see them all disabled on the network. // Expect to see them all disabled on the network.
h.assertUpdates( h.assertUpdates(
h.graph.chans(), false, h.safeDisableTimeout, h.graph.chans(), false, h.safeDisableTimeout,
@ -574,7 +582,7 @@ var stateMachineTests = []stateMachineTest{
startEnabled: true, startEnabled: true,
fn: func(h testHarness) { fn: func(h testHarness) {
// Request enables for already enabled channels. // Request enables for already enabled channels.
h.assertEnables(h.graph.chans(), nil) h.assertEnables(h.graph.chans(), nil, false)
// Manager shouldn't send out any updates. // Manager shouldn't send out any updates.
h.assertNoUpdates(h.safeDisableTimeout) h.assertNoUpdates(h.safeDisableTimeout)
}, },
@ -585,7 +593,7 @@ var stateMachineTests = []stateMachineTest{
startEnabled: false, startEnabled: false,
fn: func(h testHarness) { fn: func(h testHarness) {
// Request disables for already enabled channels. // Request disables for already enabled channels.
h.assertDisables(h.graph.chans(), nil) h.assertDisables(h.graph.chans(), nil, false)
// Manager shouldn't sent out any updates. // Manager shouldn't sent out any updates.
h.assertNoUpdates(h.safeDisableTimeout) h.assertNoUpdates(h.safeDisableTimeout)
}, },
@ -616,7 +624,7 @@ var stateMachineTests = []stateMachineTest{
// Simulate reconnect by making channels active. // Simulate reconnect by making channels active.
h.markActive(h.graph.chans()) h.markActive(h.graph.chans())
// Request that all channels be reenabled. // Request that all channels be reenabled.
h.assertEnables(h.graph.chans(), nil) h.assertEnables(h.graph.chans(), nil, false)
// Pending disable should have been canceled, and // Pending disable should have been canceled, and
// no updates sent. Channels remain enabled on the // no updates sent. Channels remain enabled on the
// network. // network.
@ -642,7 +650,7 @@ var stateMachineTests = []stateMachineTest{
// Request enable of inactive channels, expect error // Request enable of inactive channels, expect error
// indicating that channel was not active. // indicating that channel was not active.
h.assertEnables( h.assertEnables(
h.graph.chans(), netann.ErrEnableInactiveChan, h.graph.chans(), netann.ErrEnableInactiveChan, false,
) )
// No updates should be sent as a result of the failure. // No updates should be sent as a result of the failure.
h.assertNoUpdates(h.safeDisableTimeout) h.assertNoUpdates(h.safeDisableTimeout)
@ -662,7 +670,7 @@ var stateMachineTests = []stateMachineTest{
// Request that they be enabled, which should return an // Request that they be enabled, which should return an
// error as the graph doesn't have an edge for them. // error as the graph doesn't have an edge for them.
h.assertEnables( h.assertEnables(
unknownChans, channeldb.ErrEdgeNotFound, unknownChans, channeldb.ErrEdgeNotFound, false,
) )
// No updates should be sent as a result of the failure. // No updates should be sent as a result of the failure.
h.assertNoUpdates(h.safeDisableTimeout) h.assertNoUpdates(h.safeDisableTimeout)
@ -682,7 +690,7 @@ var stateMachineTests = []stateMachineTest{
// Request that they be disabled, which should return an // Request that they be disabled, which should return an
// error as the graph doesn't have an edge for them. // error as the graph doesn't have an edge for them.
h.assertDisables( h.assertDisables(
unknownChans, channeldb.ErrEdgeNotFound, unknownChans, channeldb.ErrEdgeNotFound, false,
) )
// No updates should be sent as a result of the failure. // No updates should be sent as a result of the failure.
h.assertNoUpdates(h.safeDisableTimeout) h.assertNoUpdates(h.safeDisableTimeout)
@ -712,7 +720,7 @@ var stateMachineTests = []stateMachineTest{
// Check that trying to enable the channel with unknown // Check that trying to enable the channel with unknown
// edges results in a failure. // edges results in a failure.
h.assertEnables(newChans, channeldb.ErrEdgeNotFound) h.assertEnables(newChans, channeldb.ErrEdgeNotFound, false)
// Now, insert edge policies for the channel into the // Now, insert edge policies for the channel into the
// graph, starting with the channel enabled, and mark // graph, starting with the channel enabled, and mark
@ -731,7 +739,7 @@ var stateMachineTests = []stateMachineTest{
// Finally, assert that enabling the channel doesn't // Finally, assert that enabling the channel doesn't
// return an error now that everything is in place. // return an error now that everything is in place.
h.assertEnables(newChans, nil) h.assertEnables(newChans, nil, false)
}, },
}, },
{ {
@ -759,7 +767,7 @@ var stateMachineTests = []stateMachineTest{
// Check that trying to enable the channel with unknown // Check that trying to enable the channel with unknown
// edges results in a failure. // edges results in a failure.
h.assertDisables(rmChans, channeldb.ErrEdgeNotFound) h.assertDisables(rmChans, channeldb.ErrEdgeNotFound, false)
}, },
}, },
{ {
@ -777,7 +785,7 @@ var stateMachineTests = []stateMachineTest{
// Check that trying to enable the channel with unknown // Check that trying to enable the channel with unknown
// edges results in a failure. // edges results in a failure.
h.assertDisables(rmChans, nil) h.assertDisables(rmChans, nil, false)
// Since the channels are still in the graph, we expect // Since the channels are still in the graph, we expect
// these channels to be disabled on the network. // these channels to be disabled on the network.