2019-10-06 22:56:34 +02:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/goreleaser/goreleaser/internal/artifact"
|
|
|
|
"github.com/goreleaser/goreleaser/pkg/config"
|
|
|
|
"github.com/goreleaser/goreleaser/pkg/context"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestNewGitHubClient(t *testing.T) {
|
|
|
|
t.Run("good urls", func(t *testing.T) {
|
|
|
|
_, err := NewGitHub(context.New(config.Project{
|
|
|
|
GitHubURLs: config.GitHubURLs{
|
|
|
|
API: "https://github.mycompany.com/api",
|
|
|
|
Upload: "https://github.mycompany.com/upload",
|
|
|
|
},
|
|
|
|
}))
|
|
|
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("bad api url", func(t *testing.T) {
|
|
|
|
_, err := NewGitHub(context.New(config.Project{
|
|
|
|
GitHubURLs: config.GitHubURLs{
|
|
|
|
API: "://github.mycompany.com/api",
|
|
|
|
Upload: "https://github.mycompany.com/upload",
|
|
|
|
},
|
|
|
|
}))
|
|
|
|
|
2020-03-04 06:24:51 +02:00
|
|
|
require.EqualError(t, err, `parse "://github.mycompany.com/api": missing protocol scheme`)
|
2019-10-06 22:56:34 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("bad upload url", func(t *testing.T) {
|
|
|
|
_, err := NewGitHub(context.New(config.Project{
|
|
|
|
GitHubURLs: config.GitHubURLs{
|
|
|
|
API: "https://github.mycompany.com/api",
|
|
|
|
Upload: "not a url:4994",
|
|
|
|
},
|
|
|
|
}))
|
|
|
|
|
2020-03-04 06:24:51 +02:00
|
|
|
require.EqualError(t, err, `parse "not a url:4994": first path segment in URL cannot contain colon`)
|
2019-10-06 22:56:34 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGitHubUploadReleaseIDNotInt(t *testing.T) {
|
|
|
|
var ctx = context.New(config.Project{})
|
|
|
|
client, err := NewGitHub(ctx)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
require.EqualError(
|
|
|
|
t,
|
|
|
|
client.Upload(ctx, "blah", &artifact.Artifact{}, nil),
|
|
|
|
`strconv.ParseInt: parsing "blah": invalid syntax`,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2020-07-06 15:48:17 +02:00
|
|
|
func TestGitHubReleaseURLTemplate(t *testing.T) {
|
|
|
|
var ctx = context.New(config.Project{
|
|
|
|
GitHubURLs: config.GitHubURLs{
|
|
|
|
// default URL would otherwise be set via pipe/defaults
|
|
|
|
Download: DefaultGitHubDownloadURL,
|
|
|
|
},
|
|
|
|
Release: config.Release{
|
|
|
|
GitHub: config.Repo{
|
|
|
|
Owner: "owner",
|
|
|
|
Name: "name",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
client, err := NewGitHub(ctx)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
urlTpl, err := client.ReleaseURLTemplate(ctx)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
expectedUrl := "https://github.com/owner/name/releases/download/{{ .Tag }}/{{ .ArtifactName }}"
|
|
|
|
require.Equal(t, expectedUrl, urlTpl)
|
|
|
|
}
|
|
|
|
|
2019-10-06 22:56:34 +02:00
|
|
|
func TestGitHubCreateReleaseWrongNameTemplate(t *testing.T) {
|
|
|
|
var ctx = context.New(config.Project{
|
|
|
|
Release: config.Release{
|
|
|
|
NameTemplate: "{{.dddddddddd",
|
|
|
|
},
|
|
|
|
})
|
|
|
|
client, err := NewGitHub(ctx)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
str, err := client.CreateRelease(ctx, "")
|
|
|
|
require.Empty(t, str)
|
|
|
|
require.EqualError(t, err, `template: tmpl:1: unclosed action`)
|
|
|
|
}
|