mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-29 10:57:44 +09:00 
			
		
		
		
	Replace all contexts in tests with go1.24 t.Context() --------- Co-authored-by: Giteabot <teabot@gitea.io> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			319 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			319 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2021 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package webhook
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	webhook_model "code.gitea.io/gitea/models/webhook"
 | |
| 	"code.gitea.io/gitea/modules/json"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 	api "code.gitea.io/gitea/modules/structs"
 | |
| 	webhook_module "code.gitea.io/gitea/modules/webhook"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| )
 | |
| 
 | |
| func TestDiscordPayload(t *testing.T) {
 | |
| 	dc := discordConvertor{}
 | |
| 
 | |
| 	t.Run("Create", func(t *testing.T) {
 | |
| 		p := createTestPayload()
 | |
| 
 | |
| 		pl, err := dc.Create(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] branch test created", pl.Embeds[0].Title)
 | |
| 		assert.Empty(t, pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/src/test", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Delete", func(t *testing.T) {
 | |
| 		p := deleteTestPayload()
 | |
| 
 | |
| 		pl, err := dc.Delete(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] branch test deleted", pl.Embeds[0].Title)
 | |
| 		assert.Empty(t, pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/src/test", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Fork", func(t *testing.T) {
 | |
| 		p := forkTestPayload()
 | |
| 
 | |
| 		pl, err := dc.Fork(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "test/repo2 is forked to test/repo", pl.Embeds[0].Title)
 | |
| 		assert.Empty(t, pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Push", func(t *testing.T) {
 | |
| 		p := pushTestPayload()
 | |
| 
 | |
| 		pl, err := dc.Push(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo:test] 2 new commits", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "[2020558](http://localhost:3000/test/repo/commit/2020558fe2e34debb818a514715839cabd25e778) commit message - user1\n[2020558](http://localhost:3000/test/repo/commit/2020558fe2e34debb818a514715839cabd25e778) commit message - user1", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/src/test", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("PushWithMultilineCommitMessage", func(t *testing.T) {
 | |
| 		p := pushTestMultilineCommitMessagePayload()
 | |
| 
 | |
| 		pl, err := dc.Push(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo:test] 2 new commits", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "[2020558](http://localhost:3000/test/repo/commit/2020558fe2e34debb818a514715839cabd25e778) chore: This is a commit summary - user1\n[2020558](http://localhost:3000/test/repo/commit/2020558fe2e34debb818a514715839cabd25e778) chore: This is a commit summary - user1", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("PushWithLongCommitSummary", func(t *testing.T) {
 | |
| 		p := pushTestPayloadWithCommitMessage("This is a commit summary ⚠️⚠️⚠️⚠️ containing 你好 ⚠️⚠️️\n\nThis is the message body")
 | |
| 
 | |
| 		pl, err := dc.Push(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo:test] 2 new commits", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "[2020558](http://localhost:3000/test/repo/commit/2020558fe2e34debb818a514715839cabd25e778) This is a commit summary ⚠️⚠️⚠️⚠️ containing 你好... - user1\n[2020558](http://localhost:3000/test/repo/commit/2020558fe2e34debb818a514715839cabd25e778) This is a commit summary ⚠️⚠️⚠️⚠️ containing 你好... - user1", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Issue", func(t *testing.T) {
 | |
| 		p := issueTestPayload()
 | |
| 
 | |
| 		p.Action = api.HookIssueOpened
 | |
| 		pl, err := dc.Issue(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] Issue opened: #2 crash", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "issue body", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/issues/2", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 
 | |
| 		p.Action = api.HookIssueClosed
 | |
| 		pl, err = dc.Issue(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] Issue closed: #2 crash", pl.Embeds[0].Title)
 | |
| 		assert.Empty(t, pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/issues/2", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("IssueComment", func(t *testing.T) {
 | |
| 		p := issueCommentTestPayload()
 | |
| 
 | |
| 		pl, err := dc.IssueComment(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] New comment on issue #2 crash", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "more info needed", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/issues/2#issuecomment-4", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("PullRequest", func(t *testing.T) {
 | |
| 		p := pullRequestTestPayload()
 | |
| 
 | |
| 		pl, err := dc.PullRequest(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] Pull request opened: #12 Fix bug", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "fixes bug #2", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/pulls/12", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("PullRequestComment", func(t *testing.T) {
 | |
| 		p := pullRequestCommentTestPayload()
 | |
| 
 | |
| 		pl, err := dc.IssueComment(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] New comment on pull request #12 Fix bug", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "changes requested", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/pulls/12#issuecomment-4", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Review", func(t *testing.T) {
 | |
| 		p := pullRequestTestPayload()
 | |
| 		p.Action = api.HookIssueReviewed
 | |
| 
 | |
| 		pl, err := dc.Review(p, webhook_module.HookEventPullRequestReviewApproved)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] Pull request review approved: #12 Fix bug", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "good job", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/pulls/12", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Repository", func(t *testing.T) {
 | |
| 		p := repositoryTestPayload()
 | |
| 
 | |
| 		pl, err := dc.Repository(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] Repository created", pl.Embeds[0].Title)
 | |
| 		assert.Empty(t, pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Package", func(t *testing.T) {
 | |
| 		p := packageTestPayload()
 | |
| 
 | |
| 		pl, err := dc.Package(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "Package created: GiteaContainer:latest", pl.Embeds[0].Title)
 | |
| 		assert.Empty(t, pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/user1/-/packages/container/GiteaContainer/latest", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Wiki", func(t *testing.T) {
 | |
| 		p := wikiTestPayload()
 | |
| 
 | |
| 		p.Action = api.HookWikiCreated
 | |
| 		pl, err := dc.Wiki(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] New wiki page 'index' (Wiki change comment)", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "Wiki change comment", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/wiki/index", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 
 | |
| 		p.Action = api.HookWikiEdited
 | |
| 		pl, err = dc.Wiki(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] Wiki page 'index' edited (Wiki change comment)", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "Wiki change comment", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/wiki/index", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 
 | |
| 		p.Action = api.HookWikiDeleted
 | |
| 		pl, err = dc.Wiki(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] Wiki page 'index' deleted", pl.Embeds[0].Title)
 | |
| 		assert.Empty(t, pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/wiki/index", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| 
 | |
| 	t.Run("Release", func(t *testing.T) {
 | |
| 		p := pullReleaseTestPayload()
 | |
| 
 | |
| 		pl, err := dc.Release(p)
 | |
| 		require.NoError(t, err)
 | |
| 
 | |
| 		assert.Len(t, pl.Embeds, 1)
 | |
| 		assert.Equal(t, "[test/repo] Release created: v1.0", pl.Embeds[0].Title)
 | |
| 		assert.Equal(t, "Note of first stable release", pl.Embeds[0].Description)
 | |
| 		assert.Equal(t, "http://localhost:3000/test/repo/releases/tag/v1.0", pl.Embeds[0].URL)
 | |
| 		assert.Equal(t, p.Sender.UserName, pl.Embeds[0].Author.Name)
 | |
| 		assert.Equal(t, setting.AppURL+p.Sender.UserName, pl.Embeds[0].Author.URL)
 | |
| 		assert.Equal(t, p.Sender.AvatarURL, pl.Embeds[0].Author.IconURL)
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func TestDiscordJSONPayload(t *testing.T) {
 | |
| 	p := pushTestPayload()
 | |
| 	data, err := p.JSONPayload()
 | |
| 	require.NoError(t, err)
 | |
| 
 | |
| 	hook := &webhook_model.Webhook{
 | |
| 		RepoID:     3,
 | |
| 		IsActive:   true,
 | |
| 		Type:       webhook_module.DISCORD,
 | |
| 		URL:        "https://discord.example.com/",
 | |
| 		Meta:       `{}`,
 | |
| 		HTTPMethod: "POST",
 | |
| 	}
 | |
| 	task := &webhook_model.HookTask{
 | |
| 		HookID:         hook.ID,
 | |
| 		EventType:      webhook_module.HookEventPush,
 | |
| 		PayloadContent: string(data),
 | |
| 		PayloadVersion: 2,
 | |
| 	}
 | |
| 
 | |
| 	req, reqBody, err := newDiscordRequest(t.Context(), hook, task)
 | |
| 	require.NotNil(t, req)
 | |
| 	require.NotNil(t, reqBody)
 | |
| 	require.NoError(t, err)
 | |
| 
 | |
| 	assert.Equal(t, "POST", req.Method)
 | |
| 	assert.Equal(t, "https://discord.example.com/", req.URL.String())
 | |
| 	assert.Equal(t, "sha256=", req.Header.Get("X-Hub-Signature-256"))
 | |
| 	assert.Equal(t, "application/json", req.Header.Get("Content-Type"))
 | |
| 	var body DiscordPayload
 | |
| 	err = json.NewDecoder(req.Body).Decode(&body)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Equal(t, "[2020558](http://localhost:3000/test/repo/commit/2020558fe2e34debb818a514715839cabd25e778) commit message - user1\n[2020558](http://localhost:3000/test/repo/commit/2020558fe2e34debb818a514715839cabd25e778) commit message - user1", body.Embeds[0].Description)
 | |
| }
 |