mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-10 03:47:03 +02:00
f544c5ce69
alternative to #3806 the idea is that both `context.New` and `context.Context{}` are never used in tests. not sure yet how much I like it, so far code does look a bit more readable though. --------- Signed-off-by: Carlos A Becker <caarlos0@users.noreply.github.com>
86 lines
1.6 KiB
Go
86 lines
1.6 KiB
Go
package linkedin
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"testing"
|
|
|
|
"github.com/goreleaser/goreleaser/internal/testctx"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestCreateLinkedInClient(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
cfg oauthClientConfig
|
|
wantErr error
|
|
}{
|
|
{
|
|
"non-empty context and access token",
|
|
oauthClientConfig{
|
|
Context: testctx.New(),
|
|
AccessToken: "foo",
|
|
},
|
|
nil,
|
|
},
|
|
{
|
|
"empty context",
|
|
oauthClientConfig{
|
|
Context: nil,
|
|
AccessToken: "foo",
|
|
},
|
|
fmt.Errorf("context is nil"),
|
|
},
|
|
{
|
|
"empty access token",
|
|
oauthClientConfig{
|
|
Context: testctx.New(),
|
|
AccessToken: "",
|
|
},
|
|
fmt.Errorf("empty access token"),
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
_, err := createLinkedInClient(tt.cfg)
|
|
if tt.wantErr != nil {
|
|
require.EqualError(t, err, tt.wantErr.Error())
|
|
} else {
|
|
require.NoError(t, err)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestClient_Share(t *testing.T) {
|
|
server := httptest.NewServer(http.HandlerFunc(func(rw http.ResponseWriter, req *http.Request) {
|
|
_, _ = io.WriteString(rw, `
|
|
{
|
|
"id": "foo",
|
|
"activity": "123456789"
|
|
}
|
|
`)
|
|
}))
|
|
defer server.Close()
|
|
|
|
c, err := createLinkedInClient(oauthClientConfig{
|
|
Context: testctx.New(),
|
|
AccessToken: "foo",
|
|
})
|
|
if err != nil {
|
|
t.Fatalf("could not create client: %v", err)
|
|
}
|
|
|
|
c.baseURL = server.URL
|
|
|
|
link, err := c.Share("test")
|
|
if err != nil {
|
|
t.Fatalf("could not share: %v", err)
|
|
}
|
|
|
|
wantLink := "https://www.linkedin.com/feed/update/123456789"
|
|
require.Equal(t, wantLink, link)
|
|
}
|