From e36b9574037d3ddea06a65351b57840fe05bc4a8 Mon Sep 17 00:00:00 2001 From: Keuin Date: Fri, 16 Sep 2022 21:14:50 +0800 Subject: Add test for core bilibili API wrappers. --- bilibili/streaming_test.go | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 bilibili/streaming_test.go (limited to 'bilibili/streaming_test.go') diff --git a/bilibili/streaming_test.go b/bilibili/streaming_test.go new file mode 100644 index 0000000..ef438db --- /dev/null +++ b/bilibili/streaming_test.go @@ -0,0 +1,44 @@ +package bilibili + +import ( + "context" + "errors" + "fmt" + "github.com/keuin/slbr/common" + "github.com/keuin/slbr/logging" + "log" + "os" + "testing" +) + +func TestBilibili_CopyLiveStream(t *testing.T) { + // get an online live room for testing + liveList, err := common.GetLiveListForGuestUser() + if err != nil { + t.Fatalf("cannot get live list for testing: %v", err) + } + lives := liveList.Data.Data + if len(lives) <= 0 { + t.Fatalf("no live for guest available") + } + roomId := common.RoomId(lives[0].Roomid) + + logger := log.Default() + bi := NewBilibili(logging.NewWrappedLogger(logger, "test-logger")) + + si, err := bi.GetStreamingInfo(roomId) + if err != nil { + t.Fatalf("GetStreamingInfo: %v", err) + } + + // test file open failure + testErr := fmt.Errorf("test error") + err = bi.CopyLiveStream(context.Background(), roomId, si.Data.URLs[0], func() (*os.File, error) { + return nil, testErr + }, 1048576) + if !errors.Is(err, testErr) { + t.Fatalf("Unexpected error from CopyLiveStream: %v", err) + } + + // TODO more tests +} -- cgit v1.2.3