diff options
author | Keuin <[email protected]> | 2022-09-16 21:14:50 +0800 |
---|---|---|
committer | Keuin <[email protected]> | 2022-09-16 21:14:50 +0800 |
commit | e36b9574037d3ddea06a65351b57840fe05bc4a8 (patch) | |
tree | f4ec8422a393d17bbf75b004362914f68a9c90d2 /bilibili/danmaku_server_info_test.go | |
parent | 7d8ec5f208c645fef71e2b1fd9ce1f891edfda45 (diff) |
Add test for core bilibili API wrappers.
Diffstat (limited to 'bilibili/danmaku_server_info_test.go')
-rw-r--r-- | bilibili/danmaku_server_info_test.go | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/bilibili/danmaku_server_info_test.go b/bilibili/danmaku_server_info_test.go new file mode 100644 index 0000000..3166304 --- /dev/null +++ b/bilibili/danmaku_server_info_test.go @@ -0,0 +1,39 @@ +package bilibili + +import ( + "github.com/keuin/slbr/common" + "github.com/keuin/slbr/logging" + "log" + "testing" +) + +func TestBilibili_GetDanmakuServerInfo(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 available live for guest user") + } + roomId := common.RoomId(lives[0].Roomid) + + logger := log.Default() + bi := NewBilibili(logging.NewWrappedLogger(logger, "test-logger")) + dmInfo, err := bi.GetDanmakuServerInfo(roomId) + if err != nil { + t.Fatalf("GetDanmakuServerInfo: %v", err) + } + if dmInfo.Code != 0 || + dmInfo.Message != "0" || + len(dmInfo.Data.Token) < 10 || + len(dmInfo.Data.HostList) <= 0 { + t.Fatalf("Invalid GetDanmakuServerInfo response: %v", dmInfo) + } + for _, h := range dmInfo.Data.HostList { + if h.Port == 0 || h.WssPort == 0 || h.WsPort == 0 || h.Host == "" { + t.Fatalf("Invalid host: %v", h) + } + } +} |