2019-04-20 07:44:50 +01:00
// 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 integrations
import (
"io/ioutil"
"net/http"
"net/http/httptest"
"os"
"path/filepath"
"testing"
"code.gitea.io/gitea/modules/setting"
2020-08-11 21:05:34 +01:00
"code.gitea.io/gitea/modules/util"
2021-06-09 07:33:54 +08:00
"code.gitea.io/gitea/routers"
2019-04-20 07:44:50 +01:00
2021-01-26 23:36:53 +08:00
"gitea.com/go-chi/session"
2021-03-01 21:08:10 +00:00
jsoniter "github.com/json-iterator/go"
2019-04-20 07:44:50 +01:00
"github.com/stretchr/testify/assert"
)
func getSessionID ( t * testing . T , resp * httptest . ResponseRecorder ) string {
cookies := resp . Result ( ) . Cookies ( )
found := false
sessionID := ""
for _ , cookie := range cookies {
if cookie . Name == setting . SessionConfig . CookieName {
sessionID = cookie . Value
found = true
}
}
assert . True ( t , found )
assert . NotEmpty ( t , sessionID )
return sessionID
}
func sessionFile ( tmpDir , sessionID string ) string {
return filepath . Join ( tmpDir , sessionID [ 0 : 1 ] , sessionID [ 1 : 2 ] , sessionID )
}
func sessionFileExist ( t * testing . T , tmpDir , sessionID string ) bool {
sessionFile := sessionFile ( tmpDir , sessionID )
_ , err := os . Lstat ( sessionFile )
if err != nil {
if os . IsNotExist ( err ) {
return false
}
assert . NoError ( t , err )
}
return true
}
func TestSessionFileCreation ( t * testing . T ) {
2019-11-25 23:21:37 +00:00
defer prepareTestEnv ( t ) ( )
2019-04-20 07:44:50 +01:00
oldSessionConfig := setting . SessionConfig . ProviderConfig
defer func ( ) {
setting . SessionConfig . ProviderConfig = oldSessionConfig
2021-06-09 07:33:54 +08:00
c = routers . NormalRoutes ( )
2019-04-20 07:44:50 +01:00
} ( )
var config session . Options
2021-03-01 21:08:10 +00:00
json := jsoniter . ConfigCompatibleWithStandardLibrary
2019-04-20 07:44:50 +01:00
err := json . Unmarshal ( [ ] byte ( oldSessionConfig ) , & config )
assert . NoError ( t , err )
config . Provider = "file"
// Now create a temporaryDirectory
tmpDir , err := ioutil . TempDir ( "" , "sessions" )
assert . NoError ( t , err )
defer func ( ) {
if _ , err := os . Stat ( tmpDir ) ; ! os . IsNotExist ( err ) {
2020-08-11 21:05:34 +01:00
_ = util . RemoveAll ( tmpDir )
2019-04-20 07:44:50 +01:00
}
} ( )
config . ProviderConfig = tmpDir
newConfigBytes , err := json . Marshal ( config )
assert . NoError ( t , err )
setting . SessionConfig . ProviderConfig = string ( newConfigBytes )
2021-06-09 07:33:54 +08:00
c = routers . NormalRoutes ( )
2019-04-20 07:44:50 +01:00
t . Run ( "NoSessionOnViewIssue" , func ( t * testing . T ) {
2019-11-25 23:21:37 +00:00
defer PrintCurrentTest ( t ) ( )
2019-04-20 07:44:50 +01:00
req := NewRequest ( t , "GET" , "/user2/repo1/issues/1" )
resp := MakeRequest ( t , req , http . StatusOK )
sessionID := getSessionID ( t , resp )
// We're not logged in so there should be no session
assert . False ( t , sessionFileExist ( t , tmpDir , sessionID ) )
} )
t . Run ( "CreateSessionOnLogin" , func ( t * testing . T ) {
2019-11-25 23:21:37 +00:00
defer PrintCurrentTest ( t ) ( )
2019-04-20 07:44:50 +01:00
req := NewRequest ( t , "GET" , "/user/login" )
resp := MakeRequest ( t , req , http . StatusOK )
sessionID := getSessionID ( t , resp )
// We're not logged in so there should be no session
assert . False ( t , sessionFileExist ( t , tmpDir , sessionID ) )
doc := NewHTMLParser ( t , resp . Body )
req = NewRequestWithValues ( t , "POST" , "/user/login" , map [ string ] string {
"_csrf" : doc . GetCSRF ( ) ,
"user_name" : "user2" ,
"password" : userPassword ,
} )
resp = MakeRequest ( t , req , http . StatusFound )
sessionID = getSessionID ( t , resp )
assert . FileExists ( t , sessionFile ( tmpDir , sessionID ) )
} )
}