// Copyright 2019 The Gitea Authors. All rights reserved. // Use of this source code is governed by a MIT-style // license that can be found in the LICENSE file. package migrations import ( "context" "fmt" "net/http" "os" "testing" "time" "code.gitea.io/gitea/modules/migrations/base" "github.com/stretchr/testify/assert" ) func TestGitlabDownloadRepo(t *testing.T) { // Skip tests if Gitlab token is not found gitlabPersonalAccessToken := os.Getenv("GITLAB_READ_TOKEN") if gitlabPersonalAccessToken == "" { t.Skip("skipped test because GITLAB_READ_TOKEN was not in the environment") } resp, err := http.Get("https://gitlab.com/gitea/test_repo") if err != nil || resp.StatusCode != 200 { t.Skipf("Can't access test repo, skipping %s", t.Name()) } downloader, err := NewGitlabDownloader(context.Background(), "https://gitlab.com", "gitea/test_repo", "", "", gitlabPersonalAccessToken) if err != nil { t.Fatal(fmt.Sprintf("NewGitlabDownloader is nil: %v", err)) } repo, err := downloader.GetRepoInfo() assert.NoError(t, err) // Repo Owner is blank in Gitlab Group repos assert.EqualValues(t, &base.Repository{ Name: "test_repo", Owner: "", Description: "Test repository for testing migration from gitlab to gitea", CloneURL: "https://gitlab.com/gitea/test_repo.git", OriginalURL: "https://gitlab.com/gitea/test_repo", DefaultBranch: "master", }, repo) topics, err := downloader.GetTopics() assert.NoError(t, err) assert.True(t, len(topics) == 2) assert.EqualValues(t, []string{"migration", "test"}, topics) milestones, err := downloader.GetMilestones() assert.NoError(t, err) assert.True(t, len(milestones) >= 2) for _, milestone := range milestones { switch milestone.Title { case "1.0": assertMilestoneEqual(t, "", "1.0", "", "2019-11-28 08:42:30.301 +0000 UTC", "2019-11-28 15:57:52.401 +0000 UTC", "", "closed", milestone) case "1.1.0": assertMilestoneEqual(t, "", "1.1.0", "", "2019-11-28 08:42:44.575 +0000 UTC", "2019-11-28 08:42:44.575 +0000 UTC", "", "active", milestone) } } labels, err := downloader.GetLabels() assert.NoError(t, err) assert.True(t, len(labels) >= 9) for _, l := range labels { switch l.Name { case "bug": assertLabelEqual(t, "bug", "d9534f", "", l) case "documentation": assertLabelEqual(t, "documentation", "f0ad4e", "", l) case "confirmed": assertLabelEqual(t, "confirmed", "d9534f", "", l) case "enhancement": assertLabelEqual(t, "enhancement", "5cb85c", "", l) case "critical": assertLabelEqual(t, "critical", "d9534f", "", l) case "discussion": assertLabelEqual(t, "discussion", "428bca", "", l) case "suggestion": assertLabelEqual(t, "suggestion", "428bca", "", l) case "support": assertLabelEqual(t, "support", "f0ad4e", "", l) case "duplicate": assertLabelEqual(t, "duplicate", "7F8C8D", "", l) } } releases, err := downloader.GetReleases() assert.NoError(t, err) assert.EqualValues(t, []*base.Release{ { TagName: "v0.9.99", TargetCommitish: "0720a3ec57c1f843568298117b874319e7deee75", Name: "First Release", Body: "A test release", Created: time.Date(2019, 11, 28, 9, 9, 48, 840000000, time.UTC), PublisherID: 1241334, PublisherName: "lafriks", }, }, releases[len(releases)-1:]) issues, isEnd, err := downloader.GetIssues(1, 2) assert.NoError(t, err) assert.EqualValues(t, 2, len(issues)) assert.False(t, isEnd) var ( closed1 = time.Date(2019, 11, 28, 8, 46, 23, 275000000, time.UTC) closed2 = time.Date(2019, 11, 28, 8, 45, 44, 959000000, time.UTC) ) assert.EqualValues(t, []*base.Issue{ { Number: 1, Title: "Please add an animated gif icon to the merge button", Content: "I just want the merge button to hurt my eyes a little. :stuck_out_tongue_closed_eyes:", Milestone: "1.0.0", PosterID: 1241334, PosterName: "lafriks", State: "closed", Created: time.Date(2019, 11, 28, 8, 43, 35, 459000000, time.UTC), Updated: time.Date(2019, 11, 28, 8, 46, 23, 304000000, time.UTC), Labels: []*base.Label{ { Name: "bug", }, { Name: "discussion", }, }, Reactions: []*base.Reaction{ { UserID: 1241334, UserName: "lafriks", Content: "thumbsup", }, { UserID: 1241334, UserName: "lafriks", Content: "open_mouth", }}, Closed: &closed1, }, { Number: 2, Title: "Test issue", Content: "This is test issue 2, do not touch!", Milestone: "1.1.0", PosterID: 1241334, PosterName: "lafriks", State: "closed", Created: time.Date(2019, 11, 28, 8, 44, 46, 277000000, time.UTC), Updated: time.Date(2019, 11, 28, 8, 45, 44, 987000000, time.UTC), Labels: []*base.Label{ { Name: "duplicate", }, }, Reactions: []*base.Reaction{ { UserID: 1241334, UserName: "lafriks", Content: "thumbsup", }, { UserID: 1241334, UserName: "lafriks", Content: "thumbsdown", }, { UserID: 1241334, UserName: "lafriks", Content: "laughing", }, { UserID: 1241334, UserName: "lafriks", Content: "tada", }, { UserID: 1241334, UserName: "lafriks", Content: "confused", }, { UserID: 1241334, UserName: "lafriks", Content: "hearts", }}, Closed: &closed2, }, }, issues) comments, err := downloader.GetComments(2) assert.NoError(t, err) assert.EqualValues(t, 4, len(comments)) assert.EqualValues(t, []*base.Comment{ { IssueIndex: 2, PosterID: 1241334, PosterName: "lafriks", Created: time.Date(2019, 11, 28, 8, 44, 52, 501000000, time.UTC), Content: "This is a comment", Reactions: nil, }, { IssueIndex: 2, PosterID: 1241334, PosterName: "lafriks", Created: time.Date(2019, 11, 28, 8, 45, 2, 329000000, time.UTC), Content: "changed milestone to %2", Reactions: nil, }, { IssueIndex: 2, PosterID: 1241334, PosterName: "lafriks", Created: time.Date(2019, 11, 28, 8, 45, 45, 7000000, time.UTC), Content: "closed", Reactions: nil, }, { IssueIndex: 2, PosterID: 1241334, PosterName: "lafriks", Created: time.Date(2019, 11, 28, 8, 45, 53, 501000000, time.UTC), Content: "A second comment", Reactions: nil, }, }, comments[:4]) prs, _, err := downloader.GetPullRequests(1, 1) assert.NoError(t, err) assert.Len(t, prs, 1) assert.EqualValues(t, []*base.PullRequest{ { Number: 4, OriginalNumber: 2, Title: "Test branch", Content: "do not merge this PR", Milestone: "1.0.0", PosterID: 1241334, PosterName: "lafriks", State: "opened", Created: time.Date(2019, 11, 28, 15, 56, 54, 104000000, time.UTC), Labels: []*base.Label{ { Name: "bug", }, }, Reactions: []*base.Reaction{{ UserID: 4575606, UserName: "real6543", Content: "thumbsup", }, { UserID: 4575606, UserName: "real6543", Content: "tada", }}, PatchURL: "https://gitlab.com/gitea/test_repo/-/merge_requests/2.patch", Head: base.PullRequestBranch{ Ref: "feat/test", CloneURL: "https://gitlab.com/gitea/test_repo/-/merge_requests/2", SHA: "9f733b96b98a4175276edf6a2e1231489c3bdd23", RepoName: "test_repo", OwnerName: "lafriks", }, Base: base.PullRequestBranch{ Ref: "master", SHA: "", OwnerName: "lafriks", RepoName: "test_repo", }, Closed: nil, Merged: false, MergedTime: nil, MergeCommitSHA: "", }, }, prs) rvs, err := downloader.GetReviews(1) assert.NoError(t, err) if assert.Len(t, rvs, 2) { for i := range rvs { switch rvs[i].ReviewerID { case 4102996: assert.EqualValues(t, "zeripath", rvs[i].ReviewerName) assert.EqualValues(t, "APPROVED", rvs[i].State) case 527793: assert.EqualValues(t, "axifive", rvs[i].ReviewerName) assert.EqualValues(t, "APPROVED", rvs[i].State) default: t.Errorf("Unexpected Reviewer ID: %d", rvs[i].ReviewerID) } } } rvs, err = downloader.GetReviews(2) assert.NoError(t, err) if assert.Len(t, prs, 1) { assert.EqualValues(t, 4575606, rvs[0].ReviewerID) assert.EqualValues(t, "real6543", rvs[0].ReviewerName) assert.EqualValues(t, "APPROVED", rvs[0].State) } }