File: apierrors_test.go

package info (click to toggle)
golang-github-mesos-mesos-go 0.0.6%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 11,724 kB
  • sloc: makefile: 163
file content (66 lines) | stat: -rw-r--r-- 1,682 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package apierrors

import (
	"bytes"
	"io/ioutil"
	"net/http"
	"reflect"
	"testing"
)

func TestFromResponse(t *testing.T) {
	for _, tt := range []struct {
		r *http.Response
		e error
	}{
		{nil, nil},
		{
			&http.Response{StatusCode: 200},
			nil,
		},
		{
			&http.Response{StatusCode: 400, Body: ioutil.NopCloser(bytes.NewBufferString("missing framework id"))},
			&Error{400, ErrorTable[CodeMalformedRequest] + ": missing framework id"},
		},
	} {
		rr := FromResponse(tt.r)
		if !reflect.DeepEqual(tt.e, rr) {
			t.Errorf("Expected: %v, got: %v", tt.e, rr)
		}
	}
}

func TestError(t *testing.T) {
	for _, tt := range []struct {
		code             Code
		isErr            bool
		details          string
		wantsMessage     string
		temporary        bool
		subscriptionLoss bool
	}{
		{200, false, "", "", false, false},
		{400, true, "", "malformed request", false, false},
		{400, true, "foo", "malformed request: foo", false, false},
	} {
		err := tt.code.Error(tt.details)
		if !tt.code.Matches(err) {
			t.Errorf("expected expected code %v to match that of the error %q", tt.code, err)
		}
		if tt.isErr != (err != nil) {
			t.Errorf("expected isErr %v but error was %q", tt.isErr, err)
		}
		if err != nil {
			if err.Error() != tt.wantsMessage {
				t.Errorf("Expected: %s, got: %s", tt.wantsMessage, err.Error())
			}
			apierr := err.(*Error)
			if apierr.Temporary() != tt.temporary {
				t.Errorf("expected temporary to be %v instead of %v", tt.temporary, apierr.Temporary())
			}
			if apierr.SubscriptionLoss() != tt.subscriptionLoss {
				t.Errorf("expected subscription-loss to be %v instead of %v", tt.subscriptionLoss, apierr.SubscriptionLoss())
			}
		}
	}
}