123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- // Copyright 2021 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 integrations
-
- import (
- "net/http"
- "testing"
-
- api "code.gitea.io/gitea/modules/structs"
-
- "github.com/stretchr/testify/assert"
- )
-
- func TestAPIListEmails(t *testing.T) {
- defer prepareTestEnv(t)()
-
- normalUsername := "user2"
- session := loginUser(t, normalUsername)
- token := getTokenForLoggedInUser(t, session)
-
- req := NewRequest(t, "GET", "/api/v1/user/emails?token="+token)
- resp := session.MakeRequest(t, req, http.StatusOK)
-
- var emails []*api.Email
- DecodeJSON(t, resp, &emails)
-
- assert.EqualValues(t, []*api.Email{
- {
- Email: "user2@example.com",
- Verified: true,
- Primary: true,
- },
- {
- Email: "user21@example.com",
- Verified: false,
- Primary: false,
- },
- }, emails)
- }
-
- func TestAPIAddEmail(t *testing.T) {
- defer prepareTestEnv(t)()
-
- normalUsername := "user2"
- session := loginUser(t, normalUsername)
- token := getTokenForLoggedInUser(t, session)
-
- opts := api.CreateEmailOption{
- Emails: []string{"user101@example.com"},
- }
-
- req := NewRequestWithJSON(t, "POST", "/api/v1/user/emails?token="+token, &opts)
- session.MakeRequest(t, req, http.StatusUnprocessableEntity)
-
- opts = api.CreateEmailOption{
- Emails: []string{"user22@example.com"},
- }
- req = NewRequestWithJSON(t, "POST", "/api/v1/user/emails?token="+token, &opts)
- resp := session.MakeRequest(t, req, http.StatusCreated)
-
- var emails []*api.Email
- DecodeJSON(t, resp, &emails)
- assert.EqualValues(t, []*api.Email{
- {
- Email: "user22@example.com",
- Verified: true,
- Primary: false,
- },
- }, emails)
- }
-
- func TestAPIDeleteEmail(t *testing.T) {
- defer prepareTestEnv(t)()
-
- normalUsername := "user2"
- session := loginUser(t, normalUsername)
- token := getTokenForLoggedInUser(t, session)
-
- opts := api.DeleteEmailOption{
- Emails: []string{"user22@example.com"},
- }
- req := NewRequestWithJSON(t, "DELETE", "/api/v1/user/emails?token="+token, &opts)
- session.MakeRequest(t, req, http.StatusNotFound)
-
- opts = api.DeleteEmailOption{
- Emails: []string{"user21@example.com"},
- }
- req = NewRequestWithJSON(t, "DELETE", "/api/v1/user/emails?token="+token, &opts)
- session.MakeRequest(t, req, http.StatusNoContent)
-
- req = NewRequest(t, "GET", "/api/v1/user/emails?token="+token)
- resp := session.MakeRequest(t, req, http.StatusOK)
-
- var emails []*api.Email
- DecodeJSON(t, resp, &emails)
- assert.EqualValues(t, []*api.Email{
- {
- Email: "user2@example.com",
- Verified: true,
- Primary: true,
- },
- }, emails)
- }
|