-
Notifications
You must be signed in to change notification settings - Fork 12
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
glightning: add shutdown subscription
Adds a new shutdown subscription to the plugin system, allowing plugins to be notified when lightningd is shutting down. This enables plugins to perform any necessary cleanup or finalization tasks before the daemon exits.
- Loading branch information
1 parent
08a556b
commit 0552053
Showing
4 changed files
with
158 additions
and
25 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
package jrpc2 | ||
|
||
import ( | ||
"os" | ||
"testing" | ||
"time" | ||
) | ||
|
||
func TestServer_StartUp(t *testing.T) { | ||
t.Parallel() | ||
in, err := os.CreateTemp("", "input") | ||
if err != nil { | ||
t.Fatalf("Failed to create temp file: %v", err) | ||
} | ||
defer os.Remove(in.Name()) | ||
defer in.Close() | ||
|
||
out, err := os.CreateTemp("", "output") | ||
if err != nil { | ||
t.Fatalf("Failed to create temp file: %v", err) | ||
} | ||
defer os.Remove(out.Name()) | ||
defer out.Close() | ||
|
||
server := NewServer() | ||
err = server.StartUp(in, out) | ||
if err != nil { | ||
t.Fatalf("Expected no error, got %v", err) | ||
} | ||
} | ||
|
||
func TestServer_Shutdown(t *testing.T) { | ||
t.Parallel() | ||
server := NewServer() | ||
resultChan := make(chan error) | ||
|
||
go func() { | ||
resultChan <- server.StartUp(os.Stdin, os.Stdout) | ||
}() | ||
|
||
time.Sleep(5 * time.Second) // Give some time for the server to start | ||
|
||
server.Shutdown() | ||
select { | ||
case err := <-resultChan: | ||
if err != nil { | ||
t.Fatalf("Server startup failed: %v", err) | ||
} | ||
case <-time.After(5 * time.Second): | ||
t.Fatalf("Server startup timed out") | ||
} | ||
} |