mirror of
https://github.com/idanoo/autobrr
synced 2025-07-22 08:19:12 +00:00
126 lines
3 KiB
Go
126 lines
3 KiB
Go
// Copyright (c) 2021 - 2025, Ludvig Lundgren and the autobrr contributors.
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
//go:build integration
|
|
|
|
package ops
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"os"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/autobrr/autobrr/internal/domain"
|
|
|
|
"github.com/rs/zerolog"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestOrpheusClient_GetTorrentByID(t *testing.T) {
|
|
// disable logger
|
|
zerolog.SetGlobalLevel(zerolog.Disabled)
|
|
|
|
key := "mock-key"
|
|
|
|
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
// request validation logic
|
|
apiKey := r.Header.Get("Authorization")
|
|
if !strings.Contains(apiKey, key) {
|
|
w.WriteHeader(http.StatusUnauthorized)
|
|
w.Write(nil)
|
|
return
|
|
}
|
|
|
|
if strings.Contains(r.RequestURI, "2156788") {
|
|
jsonPayload, _ := os.ReadFile("testdata/get_torrent_by_id.json")
|
|
w.Header().Set("Content-Type", "application/json")
|
|
w.WriteHeader(http.StatusOK)
|
|
w.Write(jsonPayload)
|
|
return
|
|
}
|
|
|
|
// read json response
|
|
jsonPayload, _ := os.ReadFile("testdata/get_torrent_by_id_not_found.json")
|
|
w.Header().Set("Content-Type", "application/json")
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
w.Write(jsonPayload)
|
|
}))
|
|
defer ts.Close()
|
|
|
|
type fields struct {
|
|
Url string
|
|
APIKey string
|
|
}
|
|
type args struct {
|
|
torrentID string
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
fields fields
|
|
args args
|
|
want *domain.TorrentBasic
|
|
wantErr string
|
|
}{
|
|
{
|
|
name: "get_by_id_1",
|
|
fields: fields{
|
|
Url: ts.URL,
|
|
APIKey: key,
|
|
},
|
|
args: args{torrentID: "2156788", freeleechToken: false},
|
|
want: &domain.TorrentBasic{
|
|
Id: "2156788",
|
|
InfoHash: "",
|
|
Size: "255299244",
|
|
Uploader: "uploader",
|
|
RecordLabel: "FAJo Music",
|
|
},
|
|
wantErr: "",
|
|
},
|
|
{
|
|
name: "invalid_torrent_id",
|
|
fields: fields{
|
|
Url: ts.URL,
|
|
APIKey: key,
|
|
},
|
|
args: args{torrentID: "100002", freeleechToken: false},
|
|
want: nil,
|
|
wantErr: "could not get torrent by id: 100002: status code: 400 status: failure error: bad id parameter",
|
|
},
|
|
{
|
|
name: "missing_api_key",
|
|
fields: fields{
|
|
Url: ts.URL,
|
|
APIKey: "",
|
|
},
|
|
args: args{torrentID: "100002", freeleechToken: false},
|
|
want: nil,
|
|
wantErr: "could not get torrent by id: 100002: orpheus client missing API key!",
|
|
},
|
|
{
|
|
name: "get_by_id_1_freeleech_token",
|
|
fields: fields{
|
|
Url: ts.URL,
|
|
APIKey: "",
|
|
},
|
|
args: args{torrentID: "100002", freeleechToken: true},
|
|
want: nil,
|
|
wantErr: "could not get torrent by id: 1. freeleech token not supported or no tokens available",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
c := NewClient(tt.fields.APIKey, WithUrl(ts.URL))
|
|
|
|
got, err := c.GetTorrentByID(context.Background(), tt.args.torrentID, tt.args.freeleechToken)
|
|
if tt.wantErr != "" && assert.Error(t, err) {
|
|
assert.EqualErrorf(t, err, tt.wantErr, "Error should be: %v, got: %v", tt.wantErr, err)
|
|
}
|
|
|
|
assert.Equal(t, tt.want, got)
|
|
})
|
|
}
|
|
}
|