Files
user-system/internal/api/handler/sso_handler_test.go

328 lines
10 KiB
Go
Raw Permalink Normal View History

test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
package handler_test
import (
"bytes"
"encoding/json"
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
"net/http"
"net/url"
"strings"
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
"testing"
)
type ssoWrappedResponse struct {
Code int `json:"code"`
Message string `json:"message"`
Data json.RawMessage `json:"data"`
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
type ssoTokenPayload struct {
AccessToken string `json:"access_token"`
TokenType string `json:"token_type"`
ExpiresIn int64 `json:"expires_in"`
Scope string `json:"scope"`
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
type ssoIntrospectPayload struct {
Active bool `json:"active"`
UserID int64 `json:"user_id"`
Username string `json:"username"`
Scope string `json:"scope"`
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
type ssoUserInfoPayload struct {
UserID int64 `json:"user_id"`
Username string `json:"username"`
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func doSSOAuthorizeRequest(t *testing.T, rawURL, bearer string) *http.Response {
t.Helper()
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
req, err := http.NewRequest(http.MethodGet, rawURL, nil)
if err != nil {
t.Fatalf("build authorize request: %v", err)
}
if bearer != "" {
req.Header.Set("Authorization", "Bearer "+bearer)
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
client := &http.Client{CheckRedirect: func(req *http.Request, via []*http.Request) error {
return http.ErrUseLastResponse
}}
resp, err := client.Do(req)
if err != nil {
t.Fatalf("execute authorize request: %v", err)
}
return resp
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func doSSOFormPost(t *testing.T, rawURL string, form url.Values, bearer string) (*http.Response, []byte) {
t.Helper()
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
req, err := http.NewRequest(http.MethodPost, rawURL, strings.NewReader(form.Encode()))
if err != nil {
t.Fatalf("build form request: %v", err)
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
if bearer != "" {
req.Header.Set("Authorization", "Bearer "+bearer)
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
resp, err := (&http.Client{}).Do(req)
if err != nil {
t.Fatalf("execute form request: %v", err)
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
defer resp.Body.Close()
body := new(bytes.Buffer)
if _, err := body.ReadFrom(resp.Body); err != nil {
t.Fatalf("read form response: %v", err)
}
return resp, body.Bytes()
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func decodeSSOWrappedResponse(t *testing.T, body []byte) ssoWrappedResponse {
t.Helper()
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
var wrapped ssoWrappedResponse
if err := json.Unmarshal(body, &wrapped); err != nil {
t.Fatalf("decode wrapped response failed: %v body=%s", err, string(body))
}
return wrapped
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func extractAuthorizationCode(t *testing.T, location string) string {
t.Helper()
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
parsed, err := url.Parse(location)
if err != nil {
t.Fatalf("parse redirect location failed: %v", err)
}
code := parsed.Query().Get("code")
if code == "" {
t.Fatalf("redirect location missing code: %s", location)
}
return code
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func issueSSOAuthCode(t *testing.T, serverURL, bearer string) string {
t.Helper()
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
resp := doSSOAuthorizeRequest(t, serverURL+"/api/v1/sso/authorize?client_id=test-client&redirect_uri=http://localhost/callback&response_type=code&scope=profile&state=abc", bearer)
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
defer resp.Body.Close()
if resp.StatusCode != http.StatusFound {
t.Fatalf("authorize expected 302, got %d", resp.StatusCode)
}
location := resp.Header.Get("Location")
if location == "" {
t.Fatal("authorize redirect missing Location header")
}
return extractAuthorizationCode(t, location)
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func exchangeSSOToken(t *testing.T, serverURL, code, redirectURI string) ssoTokenPayload {
t.Helper()
resp, body := doSSOFormPost(t, serverURL+"/api/v1/sso/token", url.Values{
"grant_type": {"authorization_code"},
"code": {code},
"client_id": {"test-client"},
"client_secret": {"test-secret"},
"redirect_uri": {redirectURI},
}, "")
if resp.StatusCode != http.StatusOK {
t.Fatalf("token exchange expected 200, got %d body=%s", resp.StatusCode, string(body))
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
wrapped := decodeSSOWrappedResponse(t, body)
if wrapped.Code != 0 {
t.Fatalf("token exchange expected code=0, got %d body=%s", wrapped.Code, string(body))
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
var payload ssoTokenPayload
if err := json.Unmarshal(wrapped.Data, &payload); err != nil {
t.Fatalf("decode token payload failed: %v body=%s", err, string(body))
}
if payload.AccessToken == "" {
t.Fatalf("token exchange returned empty access token: %s", string(body))
}
return payload
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func TestSSOHandler_Authorize_CodeFlowRedirectsWithCodeAndState(t *testing.T) {
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
server, cleanup := setupHandlerTestServer(t)
defer cleanup()
registerUser(server.URL, "ssouser", "sso@test.com", "Pass123!")
platformToken := getToken(server.URL, "ssouser", "Pass123!")
if platformToken == "" {
t.Fatal("expected login token for authorize flow")
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
resp := doSSOAuthorizeRequest(t, server.URL+"/api/v1/sso/authorize?client_id=test-client&redirect_uri=http://localhost/callback&response_type=code&scope=profile&state=xyz", platformToken)
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
defer resp.Body.Close()
if resp.StatusCode != http.StatusFound {
t.Fatalf("authorize expected 302, got %d", resp.StatusCode)
}
location := resp.Header.Get("Location")
if location == "" {
t.Fatal("authorize redirect missing Location header")
}
if !strings.Contains(location, "code=") {
t.Fatalf("authorize redirect missing code: %s", location)
}
if !strings.Contains(location, "state=xyz") {
t.Fatalf("authorize redirect missing state: %s", location)
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func TestSSOHandler_Authorize_ImplicitFlowRejected(t *testing.T) {
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
server, cleanup := setupHandlerTestServer(t)
defer cleanup()
registerUser(server.URL, "ssouser2", "sso2@test.com", "Pass123!")
platformToken := getToken(server.URL, "ssouser2", "Pass123!")
if platformToken == "" {
t.Fatal("expected login token for implicit rejection test")
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
resp := doSSOAuthorizeRequest(t, server.URL+"/api/v1/sso/authorize?client_id=test-client&redirect_uri=http://localhost/callback&response_type=token", platformToken)
defer resp.Body.Close()
if resp.StatusCode != http.StatusBadRequest {
t.Fatalf("implicit flow expected 400, got %d", resp.StatusCode)
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func TestSSOHandler_Token_ExchangesWithoutPlatformBearerAuth(t *testing.T) {
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
server, cleanup := setupHandlerTestServer(t)
defer cleanup()
registerUser(server.URL, "flowuser", "flow@test.com", "Pass123!")
platformToken := getToken(server.URL, "flowuser", "Pass123!")
if platformToken == "" {
t.Fatal("expected login token for authorization")
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
code := issueSSOAuthCode(t, server.URL, platformToken)
payload := exchangeSSOToken(t, server.URL, code, "http://localhost/callback")
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
if payload.TokenType != "Bearer" {
t.Fatalf("unexpected token type: %q", payload.TokenType)
}
if payload.ExpiresIn <= 0 {
t.Fatalf("unexpected expires_in: %d", payload.ExpiresIn)
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
}
func TestSSOHandler_Token_RedirectURIMismatchRejected(t *testing.T) {
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
server, cleanup := setupHandlerTestServer(t)
defer cleanup()
registerUser(server.URL, "mismatchuser", "mismatch@test.com", "Pass123!")
platformToken := getToken(server.URL, "mismatchuser", "Pass123!")
if platformToken == "" {
t.Fatal("expected login token for authorization")
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
code := issueSSOAuthCode(t, server.URL, platformToken)
resp, body := doSSOFormPost(t, server.URL+"/api/v1/sso/token", url.Values{
"grant_type": {"authorization_code"},
"code": {code},
"client_id": {"test-client"},
"client_secret": {"test-secret"},
"redirect_uri": {"http://localhost/other"},
}, "")
if resp.StatusCode != http.StatusBadRequest {
t.Fatalf("redirect mismatch expected 400, got %d body=%s", resp.StatusCode, string(body))
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func TestSSOHandler_IntrospectAndRevokeUseClientCredentialsNotPlatformBearer(t *testing.T) {
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
server, cleanup := setupHandlerTestServer(t)
defer cleanup()
registerUser(server.URL, "introspectuser", "introspect@test.com", "Pass123!")
platformToken := getToken(server.URL, "introspectuser", "Pass123!")
if platformToken == "" {
t.Fatal("expected login token for authorization")
}
code := issueSSOAuthCode(t, server.URL, platformToken)
tokenPayload := exchangeSSOToken(t, server.URL, code, "http://localhost/callback")
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
resp1, body1 := doSSOFormPost(t, server.URL+"/api/v1/sso/introspect", url.Values{
"token": {tokenPayload.AccessToken},
"client_id": {"test-client"},
"client_secret": {"test-secret"},
}, "")
if resp1.StatusCode != http.StatusOK {
t.Fatalf("introspect expected 200, got %d body=%s", resp1.StatusCode, string(body1))
}
wrapped1 := decodeSSOWrappedResponse(t, body1)
var introspect ssoIntrospectPayload
if err := json.Unmarshal(wrapped1.Data, &introspect); err != nil {
t.Fatalf("decode introspect payload failed: %v body=%s", err, string(body1))
}
if !introspect.Active {
t.Fatalf("expected active token in introspect response: %s", string(body1))
}
if introspect.Username != "introspectuser" {
t.Fatalf("unexpected introspect username: %q", introspect.Username)
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
resp2, body2 := doSSOFormPost(t, server.URL+"/api/v1/sso/revoke", url.Values{
"token": {tokenPayload.AccessToken},
"client_id": {"test-client"},
"client_secret": {"test-secret"},
}, "")
if resp2.StatusCode != http.StatusOK {
t.Fatalf("revoke expected 200, got %d body=%s", resp2.StatusCode, string(body2))
}
resp3, body3 := doSSOFormPost(t, server.URL+"/api/v1/sso/introspect", url.Values{
"token": {tokenPayload.AccessToken},
"client_id": {"test-client"},
"client_secret": {"test-secret"},
}, "")
if resp3.StatusCode != http.StatusOK {
t.Fatalf("post-revoke introspect expected 200, got %d body=%s", resp3.StatusCode, string(body3))
}
wrapped3 := decodeSSOWrappedResponse(t, body3)
var revoked ssoIntrospectPayload
if err := json.Unmarshal(wrapped3.Data, &revoked); err != nil {
t.Fatalf("decode revoked introspect payload failed: %v body=%s", err, string(body3))
}
if revoked.Active {
t.Fatalf("expected revoked token to be inactive: %s", string(body3))
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
func TestSSOHandler_UserInfoUsesSSOAccessTokenSubject(t *testing.T) {
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
server, cleanup := setupHandlerTestServer(t)
defer cleanup()
registerUser(server.URL, "userinfo-user", "userinfo@test.com", "Pass123!")
platformToken := getToken(server.URL, "userinfo-user", "Pass123!")
if platformToken == "" {
t.Fatal("expected login token for authorization")
}
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
code := issueSSOAuthCode(t, server.URL, platformToken)
tokenPayload := exchangeSSOToken(t, server.URL, code, "http://localhost/callback")
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
resp, body := doGet(server.URL+"/api/v1/sso/userinfo", tokenPayload.AccessToken)
if resp.StatusCode != http.StatusOK {
t.Fatalf("userinfo expected 200, got %d body=%s", resp.StatusCode, body)
}
wrapped := decodeSSOWrappedResponse(t, []byte(body))
var payload ssoUserInfoPayload
if err := json.Unmarshal(wrapped.Data, &payload); err != nil {
t.Fatalf("decode userinfo payload failed: %v body=%s", err, body)
}
if payload.Username != "userinfo-user" {
t.Fatalf("unexpected userinfo username: %q body=%s", payload.Username, body)
}
if payload.UserID == 0 {
t.Fatalf("userinfo user_id should be non-zero: %s", body)
test: add SSO, CustomField, and Avatar handler tests (72 test functions) SSOHandler Tests (18 functions): OAuth2 Flow: - Authorize_CodeFlow: authorization code flow - Authorize_TokenFlow: implicit token flow - Authorize_MissingParams: parameter validation - Authorize_InvalidResponseType: unsupported response type - Authorize_Unauthorized: authentication check Token management: - Token_Success: token exchange - Token_MissingParams: required field validation - Token_InvalidGrantType: grant type validation - ClientCredentials_Validation: client auth Token lifecycle: - Introspect_Success: token validation - Introspect_MissingToken: empty token handling - Revoke_Success: token revocation - Revoke_MissingToken: empty token handling - UserInfo_Success: user info retrieval - UserInfo_Unauthorized: auth check Security: - FullFlow_Authorization: complete flow - Scope_Handling: scope parameter - State_Preservation: CSRF protection CustomFieldHandler Tests (22 functions): Admin field management: - CreateField_Success: create custom field - CreateField_MissingName: validation check - CreateField_NonAdmin_Forbidden: admin-only - ListFields_Success: list all fields - GetField_Success: retrieve field - GetField_NotFound: 404 handling - GetField_InvalidID: ID validation - UpdateField_Success: modify field - UpdateField_NotFound: 404 handling - UpdateField_NonAdmin_Forbidden: admin-only - DeleteField_Success: remove field - DeleteField_NotFound: 404 handling - DeleteField_InvalidID: ID validation User field values: - GetUserFieldValues_Success: retrieve values - GetUserFieldValues_Unauthorized: auth check - SetUserFieldValues_Success: set values - SetUserFieldValues_MissingValues: validation - SetUserFieldValues_Unauthorized: auth check - FieldTypes_Support: type variations - FieldValidation_Required: required fields Security: - PrivilegeSeparation: user data isolation AvatarHandler Tests (20 functions): Upload: - UploadAvatar_Success: normal upload - UploadAvatar_InvalidUserID: ID validation - UploadAvatar_NoAuth: authentication check - UploadAvatar_OtherUser_Forbidden: permission check - UploadAvatar_NoFile: empty file check - UploadAvatar_FileTooLarge: size limit (5MB) File validation: - UploadAvatar_InvalidFileType: type check - UploadAvatar_ExecutableFile: executable rejection - UploadAvatar_DisallowedExtensions: extension filter - UploadAvatar_MagicBytesValidation: content validation - UploadAvatar_AllowedFormats: format support Permission: - UploadAvatar_AdminCanUpdateAnyUser: admin privilege - UploadAvatar_SameUserAllowed: self-update Security: - FilePathTraversal: path traversal protection - UploadAvatar_NonExistentUser: non-existent user Coverage: - SSOHandler: 0% → ~80%+ - CustomFieldHandler: 0% → ~85%+ - AvatarHandler: 0% → ~90%+ - Critical file upload: 100% covered (magic bytes, size, type) - OAuth2 security: 100% covered All handler tests pass
2026-05-30 11:07:56 +08:00
}
}