2022-11-08 20:22:02 +00:00
|
|
|
package web_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"h4kor/owl-blogs"
|
|
|
|
main "h4kor/owl-blogs/cmd/owl/web"
|
|
|
|
"h4kor/owl-blogs/test/assertions"
|
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"net/url"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestMicropubMinimalArticle(t *testing.T) {
|
|
|
|
repo, user := getSingleUserTestRepo()
|
|
|
|
user.ResetPassword("testpassword")
|
|
|
|
|
|
|
|
code, _ := user.GenerateAuthCode(
|
|
|
|
"test", "test", "test", "test", "test",
|
|
|
|
)
|
|
|
|
token, _, _ := user.GenerateAccessToken(owl.AuthCode{
|
|
|
|
Code: code,
|
|
|
|
ClientId: "test",
|
|
|
|
RedirectUri: "test",
|
|
|
|
CodeChallenge: "test",
|
|
|
|
CodeChallengeMethod: "test",
|
|
|
|
Scope: "test",
|
|
|
|
})
|
|
|
|
|
|
|
|
// Create Request and Response
|
|
|
|
form := url.Values{}
|
|
|
|
form.Add("h", "entry")
|
|
|
|
form.Add("name", "Test Article")
|
|
|
|
form.Add("content", "Test Content")
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST", user.MicropubUrl(), strings.NewReader(form.Encode()))
|
|
|
|
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
|
|
|
req.Header.Add("Content-Length", strconv.Itoa(len(form.Encode())))
|
|
|
|
req.Header.Add("Authorization", "Bearer "+token)
|
|
|
|
assertions.AssertNoError(t, err, "Error creating request")
|
|
|
|
rr := httptest.NewRecorder()
|
|
|
|
router := main.SingleUserRouter(&repo)
|
|
|
|
router.ServeHTTP(rr, req)
|
|
|
|
|
|
|
|
assertions.AssertStatus(t, rr, http.StatusCreated)
|
|
|
|
}
|
2022-11-19 12:43:10 +00:00
|
|
|
|
|
|
|
func TestMicropubWithoutName(t *testing.T) {
|
|
|
|
repo, user := getSingleUserTestRepo()
|
|
|
|
user.ResetPassword("testpassword")
|
|
|
|
|
|
|
|
code, _ := user.GenerateAuthCode(
|
|
|
|
"test", "test", "test", "test", "test",
|
|
|
|
)
|
|
|
|
token, _, _ := user.GenerateAccessToken(owl.AuthCode{
|
|
|
|
Code: code,
|
|
|
|
ClientId: "test",
|
|
|
|
RedirectUri: "test",
|
|
|
|
CodeChallenge: "test",
|
|
|
|
CodeChallengeMethod: "test",
|
|
|
|
Scope: "test",
|
|
|
|
})
|
|
|
|
|
|
|
|
// Create Request and Response
|
|
|
|
form := url.Values{}
|
|
|
|
form.Add("h", "entry")
|
|
|
|
form.Add("content", "Test Content")
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST", user.MicropubUrl(), strings.NewReader(form.Encode()))
|
|
|
|
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
|
|
|
req.Header.Add("Content-Length", strconv.Itoa(len(form.Encode())))
|
|
|
|
req.Header.Add("Authorization", "Bearer "+token)
|
|
|
|
assertions.AssertNoError(t, err, "Error creating request")
|
|
|
|
rr := httptest.NewRecorder()
|
|
|
|
router := main.SingleUserRouter(&repo)
|
|
|
|
router.ServeHTTP(rr, req)
|
|
|
|
|
|
|
|
assertions.AssertStatus(t, rr, http.StatusCreated)
|
|
|
|
loc_header := rr.Header().Get("Location")
|
|
|
|
assertions.Assert(t, loc_header != "", "Location header should be set")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestMicropubAccessTokenInBody(t *testing.T) {
|
|
|
|
repo, user := getSingleUserTestRepo()
|
|
|
|
user.ResetPassword("testpassword")
|
|
|
|
|
|
|
|
code, _ := user.GenerateAuthCode(
|
|
|
|
"test", "test", "test", "test", "test",
|
|
|
|
)
|
|
|
|
token, _, _ := user.GenerateAccessToken(owl.AuthCode{
|
|
|
|
Code: code,
|
|
|
|
ClientId: "test",
|
|
|
|
RedirectUri: "test",
|
|
|
|
CodeChallenge: "test",
|
|
|
|
CodeChallengeMethod: "test",
|
|
|
|
Scope: "test",
|
|
|
|
})
|
|
|
|
|
|
|
|
// Create Request and Response
|
|
|
|
form := url.Values{}
|
|
|
|
form.Add("h", "entry")
|
|
|
|
form.Add("content", "Test Content")
|
|
|
|
form.Add("access_token", token)
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST", user.MicropubUrl(), strings.NewReader(form.Encode()))
|
|
|
|
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
|
|
|
req.Header.Add("Content-Length", strconv.Itoa(len(form.Encode())))
|
|
|
|
assertions.AssertNoError(t, err, "Error creating request")
|
|
|
|
rr := httptest.NewRecorder()
|
|
|
|
router := main.SingleUserRouter(&repo)
|
|
|
|
router.ServeHTTP(rr, req)
|
|
|
|
|
|
|
|
assertions.AssertStatus(t, rr, http.StatusCreated)
|
|
|
|
loc_header := rr.Header().Get("Location")
|
|
|
|
assertions.Assert(t, loc_header != "", "Location header should be set")
|
|
|
|
}
|
|
|
|
|
2022-11-19 13:08:16 +00:00
|
|
|
// func TestMicropubAccessTokenInBoth(t *testing.T) {
|
|
|
|
// repo, user := getSingleUserTestRepo()
|
|
|
|
// user.ResetPassword("testpassword")
|
|
|
|
|
|
|
|
// code, _ := user.GenerateAuthCode(
|
|
|
|
// "test", "test", "test", "test", "test",
|
|
|
|
// )
|
|
|
|
// token, _, _ := user.GenerateAccessToken(owl.AuthCode{
|
|
|
|
// Code: code,
|
|
|
|
// ClientId: "test",
|
|
|
|
// RedirectUri: "test",
|
|
|
|
// CodeChallenge: "test",
|
|
|
|
// CodeChallengeMethod: "test",
|
|
|
|
// Scope: "test",
|
|
|
|
// })
|
|
|
|
|
|
|
|
// // Create Request and Response
|
|
|
|
// form := url.Values{}
|
|
|
|
// form.Add("h", "entry")
|
|
|
|
// form.Add("content", "Test Content")
|
|
|
|
// form.Add("access_token", token)
|
|
|
|
|
|
|
|
// req, err := http.NewRequest("POST", user.MicropubUrl(), strings.NewReader(form.Encode()))
|
|
|
|
// req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
|
|
|
// req.Header.Add("Content-Length", strconv.Itoa(len(form.Encode())))
|
|
|
|
// req.Header.Add("Authorization", "Bearer "+token)
|
|
|
|
// assertions.AssertNoError(t, err, "Error creating request")
|
|
|
|
// rr := httptest.NewRecorder()
|
|
|
|
// router := main.SingleUserRouter(&repo)
|
|
|
|
// router.ServeHTTP(rr, req)
|
|
|
|
|
|
|
|
// assertions.AssertStatus(t, rr, http.StatusBadRequest)
|
|
|
|
// }
|
|
|
|
|
|
|
|
func TestMicropubNoAccessToken(t *testing.T) {
|
2022-11-19 12:43:10 +00:00
|
|
|
repo, user := getSingleUserTestRepo()
|
|
|
|
user.ResetPassword("testpassword")
|
|
|
|
|
|
|
|
code, _ := user.GenerateAuthCode(
|
|
|
|
"test", "test", "test", "test", "test",
|
|
|
|
)
|
2022-11-19 13:08:16 +00:00
|
|
|
user.GenerateAccessToken(owl.AuthCode{
|
2022-11-19 12:43:10 +00:00
|
|
|
Code: code,
|
|
|
|
ClientId: "test",
|
|
|
|
RedirectUri: "test",
|
|
|
|
CodeChallenge: "test",
|
|
|
|
CodeChallengeMethod: "test",
|
|
|
|
Scope: "test",
|
|
|
|
})
|
|
|
|
|
|
|
|
// Create Request and Response
|
|
|
|
form := url.Values{}
|
|
|
|
form.Add("h", "entry")
|
|
|
|
form.Add("content", "Test Content")
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST", user.MicropubUrl(), strings.NewReader(form.Encode()))
|
|
|
|
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
|
|
|
req.Header.Add("Content-Length", strconv.Itoa(len(form.Encode())))
|
|
|
|
assertions.AssertNoError(t, err, "Error creating request")
|
|
|
|
rr := httptest.NewRecorder()
|
|
|
|
router := main.SingleUserRouter(&repo)
|
|
|
|
router.ServeHTTP(rr, req)
|
|
|
|
|
2022-11-19 13:08:16 +00:00
|
|
|
assertions.AssertStatus(t, rr, http.StatusUnauthorized)
|
2022-11-19 12:43:10 +00:00
|
|
|
}
|