mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 08:58:24 +00:00 
			
		
		
		
	#32057 improves the CSRF handling and is worth to backport
This commit is contained in:
		| @@ -5,12 +5,10 @@ package integration | ||||
|  | ||||
| import ( | ||||
| 	"net/http" | ||||
| 	"strings" | ||||
| 	"testing" | ||||
|  | ||||
| 	"code.gitea.io/gitea/models/unittest" | ||||
| 	user_model "code.gitea.io/gitea/models/user" | ||||
| 	"code.gitea.io/gitea/modules/setting" | ||||
| 	"code.gitea.io/gitea/tests" | ||||
|  | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| @@ -25,28 +23,12 @@ func TestCsrfProtection(t *testing.T) { | ||||
| 	req := NewRequestWithValues(t, "POST", "/user/settings", map[string]string{ | ||||
| 		"_csrf": "fake_csrf", | ||||
| 	}) | ||||
| 	session.MakeRequest(t, req, http.StatusSeeOther) | ||||
|  | ||||
| 	resp := session.MakeRequest(t, req, http.StatusSeeOther) | ||||
| 	loc := resp.Header().Get("Location") | ||||
| 	assert.Equal(t, setting.AppSubURL+"/", loc) | ||||
| 	resp = session.MakeRequest(t, NewRequest(t, "GET", loc), http.StatusOK) | ||||
| 	htmlDoc := NewHTMLParser(t, resp.Body) | ||||
| 	assert.Equal(t, "Bad Request: invalid CSRF token", | ||||
| 		strings.TrimSpace(htmlDoc.doc.Find(".ui.message").Text()), | ||||
| 	) | ||||
| 	resp := session.MakeRequest(t, req, http.StatusBadRequest) | ||||
| 	assert.Contains(t, resp.Body.String(), "Invalid CSRF token") | ||||
|  | ||||
| 	// test web form csrf via header. TODO: should use an UI api to test | ||||
| 	req = NewRequest(t, "POST", "/user/settings") | ||||
| 	req.Header.Add("X-Csrf-Token", "fake_csrf") | ||||
| 	session.MakeRequest(t, req, http.StatusSeeOther) | ||||
|  | ||||
| 	resp = session.MakeRequest(t, req, http.StatusSeeOther) | ||||
| 	loc = resp.Header().Get("Location") | ||||
| 	assert.Equal(t, setting.AppSubURL+"/", loc) | ||||
| 	resp = session.MakeRequest(t, NewRequest(t, "GET", loc), http.StatusOK) | ||||
| 	htmlDoc = NewHTMLParser(t, resp.Body) | ||||
| 	assert.Equal(t, "Bad Request: invalid CSRF token", | ||||
| 		strings.TrimSpace(htmlDoc.doc.Find(".ui.message").Text()), | ||||
| 	) | ||||
| 	resp = session.MakeRequest(t, req, http.StatusBadRequest) | ||||
| 	assert.Contains(t, resp.Body.String(), "Invalid CSRF token") | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user