Documentation ¶
Overview ¶
Package testhelpers provides the interface and features to run the Gherkin tests.
Index ¶
- Constants
- func BindGodogCmdFlags()
- func EmptyDB(db *sql.DB)
- func InitializeScenario(s *godog.ScenarioContext)
- func InsertBatch(db *sql.DB, tableName string, data []map[string]interface{})
- func LoadFixture(db *sql.DB, fileName string)
- func MockDBTime(timeStrRaw string)
- func OpenRawDBConnection() (*sql.DB, error)
- func RestoreDBTime()
- func RunConcurrently(f func(), threadsNumber int)
- func RunGodogTests(t *testing.T, tags string)
- func SendTestHTTPRequest(ts *httptest.Server, method, path string, headers map[string][]string, ...) (response *http.Response, responseBody string, err error)
- func SetupDBWithFixture(fixtureNames ...string) *database.DB
- func SetupDBWithFixtureString(fixtures ...string) *database.DB
- func SuppressOutputIfPasses(t *testing.T)
- func ValidateJSONContentType(resp *http.Response) error
- func VerifyTestHTTPRequestWithToken(t *testing.T, hookedAppServer *httptest.Server, token string, ...)
- type PropagationStepsSet
- type PropagationVerifier
- type PropagationVerifierHookFunc
- type TestContext
- func (ctx *TestContext) AllUsersGroupIsDefinedAsTheGroup(group string) error
- func (ctx *TestContext) DBGroupsAncestorsAreComputed() error
- func (ctx *TestContext) DBHasTable(tableName string, data *godog.Table) error
- func (ctx *TestContext) DBHasUsers(data *godog.Table) error
- func (ctx *TestContext) DBItemsAncestorsAndPermissionsAreComputed() error
- func (ctx *TestContext) DBTimeNow(timeStrRaw string) error
- func (ctx *TestContext) FalsifiedSignedTokenIsDistributed(varName, signerName string, jsonPayload *godog.DocString) error
- func (ctx *TestContext) GroupHasGrantViewPermissionOnItem(viewValue, group, item string) error
- func (ctx *TestContext) GroupHasValidatedResultOnItem(group, item string) error
- func (ctx *TestContext) GroupHasViewPermissionOnItem(group, viewPermissionValue, item string) error
- func (ctx *TestContext) GroupHasWatchPermissionOnItem(group, watchValue, item string) error
- func (ctx *TestContext) GroupIsAChildOfTheGroup(childGroup, parentGroup string) error
- func (ctx *TestContext) GroupIsAManagerOfTheGroupAndCanGrantGroupAccess(managerGroup, group string) error
- func (ctx *TestContext) GroupIsAManagerOfTheGroupAndCanManageMembershipsAndGroup(managerGroup, group string) error
- func (ctx *TestContext) GroupIsAManagerOfTheGroupAndCanWatchItsMembers(managerGroup, group string) error
- func (ctx *TestContext) GroupIsAMemberOfTheGroup(childGroupName, parentGroupName string)
- func (ctx *TestContext) IAm(name string) error
- func (ctx *TestContext) IAmAManagerOfTheGroup(group string) error
- func (ctx *TestContext) IAmAManagerOfTheGroupAndCanWatchItsMembers(group string) error
- func (ctx *TestContext) IAmAManagerOfTheGroupWithID(group string) error
- func (ctx *TestContext) IAmAMemberOfTheGroup(name string) error
- func (ctx *TestContext) IAmAMemberOfTheGroupWithID(group string) error
- func (ctx *TestContext) IAmPartOfTheHelperGroupOfTheThread() error
- func (ctx *TestContext) IAmUserWithID(userID int64) error
- func (ctx *TestContext) ICanRequestHelpToTheGroupWithIDOnTheItemWithID(group, item string) error
- func (ctx *TestContext) IHavePermissionOnItem(permType, permValue, item string) error
- func (ctx *TestContext) IHaveValidatedResultOnItem(item string) error
- func (ctx *TestContext) IHaveViewPermissionOnItem(viewValue, item string) error
- func (ctx *TestContext) IHaveWatchPermissionOnItem(watchValue, item string) error
- func (ctx *TestContext) ISendrequestTo(method string, path string) error
- func (ctx *TestContext) ISendrequestToWithBody(method string, path string, body *godog.DocString) error
- func (ctx *TestContext) ItShouldBeAJSONArrayWithEntries(count int) error
- func (ctx *TestContext) LogsShouldContain(docString *godog.DocString) error
- func (ctx *TestContext) ScenarioTeardown(*godog.Scenario, error)
- func (ctx *TestContext) ServerTimeIsFrozen() error
- func (ctx *TestContext) ServerTimeNow(timeStr string) error
- func (ctx *TestContext) SetGroupPermissionOnItem(permission, value, group, item string) error
- func (ctx *TestContext) SetGroupPermissionWithSourceGroupAndOriginOnItem(permission, value, group, item, sourceGroup, origin string) error
- func (ctx *TestContext) SetupTestContext(sc *godog.Scenario)
- func (ctx *TestContext) SignedTokenIsDistributed(varName, signerName string, jsonPayload *godog.DocString) error
- func (ctx *TestContext) TableAtColumnValueShouldBe(tableName, columnName, columnValues string, data *godog.Table) error
- func (ctx *TestContext) TableAtColumnValueShouldBeEmpty(tableName, columnName, valuesStr string) error
- func (ctx *TestContext) TableShouldBe(tableName string, data *godog.Table) error
- func (ctx *TestContext) TableShouldBeEmpty(tableName string) error
- func (ctx *TestContext) TableShouldNotContainColumnValue(tableName, columnName, columnValues string) error
- func (ctx *TestContext) TableShouldStayUnchanged(tableName string) error
- func (ctx *TestContext) TableShouldStayUnchangedButTheRowWithColumnValue(tableName, columnName, columnValues string) error
- func (ctx *TestContext) TableShouldStayUnchangedButTheRowsWithColumnValueShouldBeDeleted(tableName, columnNames, columnValues string) error
- func (ctx *TestContext) TheApplicationConfigIs(yamlConfig *godog.DocString) error
- func (ctx *TestContext) TheContextVariableIs(variableName, value string) error
- func (ctx *TestContext) TheFieldOfTheGroupShouldBe(field, group, value string) error
- func (ctx *TestContext) TheGeneratedAuthKeyIs(generatedKey string) error
- func (ctx *TestContext) TheGeneratedGroupCodeIs(generatedCode string) error
- func (ctx *TestContext) TheGeneratedGroupCodesAre(generatedCodes string) error
- func (ctx *TestContext) TheLoginModuleAccountEndpointForTokenReturns(authToken string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheLoginModuleCreateEndpointWithParamsReturns(params string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheLoginModuleDeleteEndpointWithParamsReturns(params string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheLoginModuleLTIResultSendEndpointForUserIDContentIDScoreReturns(userID, contentID, score string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheLoginModuleTokenEndpointForCodeAndCodeVerifierAndRedirectURIReturns(code, codeVerifier, redirectURI string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheLoginModuleTokenEndpointForCodeAndCodeVerifierReturns(code, codeVerifier string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheLoginModuleTokenEndpointForCodeReturns(code string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheLoginModuleTokenEndpointForRefreshTokenReturns(refreshToken string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheLoginModuleUnlinkClientEndpointForUserIDReturns(userID string, statusCode int, body *godog.DocString) error
- func (ctx *TestContext) TheRequestHeaderIs(name, value string) error
- func (ctx *TestContext) TheResponseAtInJSONShouldBe(jsonPath string, wants *godog.DocString) error
- func (ctx *TestContext) TheResponseAtShouldBe(jsonPath string, wants *godog.Table) error
- func (ctx *TestContext) TheResponseAtShouldBeTheBase64OfAnAES256GCMEncryptedJSONObjectContaining(jsonPath string, expectedJSONParam *godog.DocString) error
- func (ctx *TestContext) TheResponseAtShouldBeTheValue(jsonPath, value string) error
- func (ctx *TestContext) TheResponseBodyShouldBe(body *godog.DocString) (err error)
- func (ctx *TestContext) TheResponseBodyShouldBeJSON(body *godog.DocString) (err error)
- func (ctx *TestContext) TheResponseCodeShouldBe(code int) error
- func (ctx *TestContext) TheResponseDecodedBodyShouldBeJSON(responseType string, body *godog.DocString) (err error)
- func (ctx *TestContext) TheResponseErrorMessageShouldContain(s string) (err error)
- func (ctx *TestContext) TheResponseHeaderShouldBe(headerName, headerValue string) (err error)
- func (ctx *TestContext) TheResponseHeaderShouldNotBeSet(headerName string) (err error)
- func (ctx *TestContext) TheResponseHeadersShouldBe(headerName string, headersValue *godog.DocString) (err error)
- func (ctx *TestContext) TheResponseShouldBe(kind string) error
- func (ctx *TestContext) TheTemplateConstantIsDocString(name string, value *godog.DocString) error
- func (ctx *TestContext) TheTemplateConstantIsString(name, value string) error
- func (ctx *TestContext) ThereAreCountAccessTokensForUser(count int, user string) error
- func (ctx *TestContext) ThereAreCountSessionsForUser(count int, user string) error
- func (ctx *TestContext) ThereAreTheFollowingAccessTokens(accessTokens *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingGroupPendingRequests(entries *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingGroups(groups *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingItemPermissions(itemPermissions *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingItemRelations(itemPermissions *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingItems(items *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingSessions(sessions *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingTasks(tasks *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingThreads(threads *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingUsers(users *godog.Table) error
- func (ctx *TestContext) ThereAreTheFollowingValidatedResults(results *godog.Table) error
- func (ctx *TestContext) ThereIsAGroup(group string) error
- func (ctx *TestContext) ThereIsATeam(group string) error
- func (ctx *TestContext) ThereIsAThreadWith(parameters string) error
- func (ctx *TestContext) ThereIsAUser(name string) error
- func (ctx *TestContext) ThereIsNoAccessToken(accessToken string) error
- func (ctx *TestContext) ThereIsNoSessionID(session string) error
- func (ctx *TestContext) ThereIsNoThreadWith(parameters string) error
- func (ctx *TestContext) ThereShouldBeNoGroupPendingRequestsForTheGroupWithTheType(group, requestType string) error
- func (ctx *TestContext) ThereShouldBeNoGroupPendingRequestsForTheMemberWithTheType(member, requestType string) error
- func (ctx *TestContext) ThereShouldBeTheFollowingGroupMembershipChanges(entries *godog.Table) error
- func (ctx *TestContext) ThereShouldBeTheFollowingGroupPendingRequests(entries *godog.Table) error
- func (ctx *TestContext) TimeIsFrozen() error
- func (ctx *TestContext) TimeNow(timeStr string) error
- func (ctx *TestContext) UserCanRequestHelpToOnItem(helperGroup, user, item string) error
- func (ctx *TestContext) UserIsAMemberOfTheGroup(user, group string) error
- func (ctx *TestContext) UserIsAMemberOfTheGroupWhoHasApprovedAccessToHisPersonalInfo(user, group string) error
- func (ctx *TestContext) UserIsOwnerOfItem(isOwner, user, item string) error
- func (ctx *TestContext) UserShouldBeAMemberOfTheGroup(user, group string) error
- func (ctx *TestContext) UserShouldNotBeAMemberOfTheGroup(user, group string) error
Constants ¶
const ( // PropagationStepSanityCheck is a fake propagation step which is called by PropagationVerifier // before triggering propagations in order to check that the hook is working without errors. PropagationStepSanityCheck database.PropagationStep = "sanity check" // PropagationStepAfterAllPropagations is a fake propagation step which is called by PropagationVerifier after all propagations. PropagationStepAfterAllPropagations database.PropagationStep = "after all propagations" )
Variables ¶
This section is empty.
Functions ¶
func BindGodogCmdFlags ¶
func BindGodogCmdFlags()
BindGodogCmdFlags binds the command arguments into the Godog options.
func InitializeScenario ¶
func InitializeScenario(s *godog.ScenarioContext)
InitializeScenario binds the supported steps to the verifying functions.
func InsertBatch ¶
InsertBatch insert the data into the table with the name given.
func LoadFixture ¶
LoadFixture loads fixtures from `<current_pkg_dir>/testdata/<fileName>/` directory or `<current_pkg_dir>/testdata/<fileName>` file. Each file in this directory must be in yaml format. If a file name satisfies '*.chain.yaml' mask, the file is treated as a tableName->[]dataRow map. Otherwise, data will be loaded into table with the same name as the filename (without extension). Note that you should probably empty the DB before using this function.
func MockDBTime ¶
func MockDBTime(timeStrRaw string)
MockDBTime replaces the DB NOW() function call with a given constant value in all the queries.
func OpenRawDBConnection ¶
OpenRawDBConnection creates a new connection to the DB specified in the config.
func RestoreDBTime ¶
func RestoreDBTime()
RestoreDBTime restores the usual behavior of the NOW() function.
func RunConcurrently ¶
func RunConcurrently(f func(), threadsNumber int)
RunConcurrently runs a given function concurrently.
func RunGodogTests ¶
RunGodogTests launches GoDog tests (bdd tests) for the current directory (the one from the tested package).
func SendTestHTTPRequest ¶ added in v2.21.4
func SendTestHTTPRequest(ts *httptest.Server, method, path string, headers map[string][]string, body io.Reader) ( response *http.Response, responseBody string, err error, )
SendTestHTTPRequest sends an HTTP request to a given path on the test server. It returns the response and the response body as a string. The response body is read completely and closed. The timeout for requests is set to 5 seconds.
func SetupDBWithFixture ¶
SetupDBWithFixture creates a new DB connection, empties the DB, and loads a fixture.
func SetupDBWithFixtureString ¶
SetupDBWithFixtureString creates a new DB connection, empties the DB, and loads fixtures from the strings (yaml with a tableName->[]dataRow map).
func SuppressOutputIfPasses ¶
SuppressOutputIfPasses immediately mutes output (to both STDOUT and STDERR) of the test so that the output will only be shown if the test fails. The cleanup part is scheduled to be run automatically, no need to clean up manually.
Note: This function will only work when the test is not run in parallel within the test binary, i.e. when the test (or its parents) haven't called t.Parallel(), otherwise it will panic. After the output is suppressed, t.Parallel() for the test will panic.
Note: This function does nothing if the test is run in verbose mode.
func ValidateJSONContentType ¶
ValidateJSONContentType validates the content-type header of the response is json If not, return an error.
func VerifyTestHTTPRequestWithToken ¶ added in v2.21.4
func VerifyTestHTTPRequestWithToken(t *testing.T, hookedAppServer *httptest.Server, token string, expectedStatusCode int, method string, path string, headers map[string][]string, body interface{}, )
VerifyTestHTTPRequestWithToken makes an HTTP request to the given path on the test server with the given token and verifies that the response status code is as expected. Note, that the request is made with a 5-second timeout.
Types ¶
type PropagationStepsSet ¶ added in v2.21.4
type PropagationStepsSet = golang.Set[database.PropagationStep]
PropagationStepsSet is a set of propagation steps.
type PropagationVerifier ¶ added in v2.21.4
type PropagationVerifier struct {
// contains filtered or unexported fields
}
PropagationVerifier is a helper to test the propagation steps. It allows to run the code that triggers propagations and the code that should be executed before and after each propagation step. It also allows to check that the required propagation steps were called. Also, the propagation verifier detects infinite loops in the propagation steps by limiting the number of calls to each step.
func NewPropagationVerifier ¶ added in v2.21.4
func NewPropagationVerifier(requiredPropagationSteps *PropagationStepsSet) *PropagationVerifier
NewPropagationVerifier creates a new PropagationVerifier with the required propagation steps.
func (*PropagationVerifier) Run ¶ added in v2.21.4
func (pv *PropagationVerifier) Run( t *testing.T, codeTriggeringPropagations func(dataStore *database.DataStore, appServer *httptest.Server), )
Run runs the propagation verifier.
func (*PropagationVerifier) WithFixture ¶ added in v2.21.4
func (pv *PropagationVerifier) WithFixture(fixture string) *PropagationVerifier
WithFixture sets the DB fixture to load before running the verification.
func (*PropagationVerifier) WithHook ¶ added in v2.21.4
func (pv *PropagationVerifier) WithHook(hookFunc PropagationVerifierHookFunc) *PropagationVerifier
WithHook sets the hook function that will be called before each propagation step and before and after all propagations.
type PropagationVerifierHookFunc ¶ added in v2.21.4
type PropagationVerifierHookFunc func(step database.PropagationStep, allStepsCounter, currentStepCounter int, dataStore *database.DataStore, appServer *httptest.Server)
PropagationVerifierHookFunc is a function that is called by PropagationVerifier before each propagation step and before and after all propagations.
type TestContext ¶
type TestContext struct {
// contains filtered or unexported fields
}
TestContext implements context for tests.
func (*TestContext) AllUsersGroupIsDefinedAsTheGroup ¶
func (ctx *TestContext) AllUsersGroupIsDefinedAsTheGroup(group string) error
AllUsersGroupIsDefinedAsTheGroup creates and sets the allUsersGroup.
func (*TestContext) DBGroupsAncestorsAreComputed ¶
func (ctx *TestContext) DBGroupsAncestorsAreComputed() error
DBGroupsAncestorsAreComputed computes the groups_ancestors table.
func (*TestContext) DBHasTable ¶
func (ctx *TestContext) DBHasTable(tableName string, data *godog.Table) error
DBHasTable inserts the data from the Godog table into the database table.
func (*TestContext) DBHasUsers ¶
func (ctx *TestContext) DBHasUsers(data *godog.Table) error
DBHasUsers inserts the data from the Godog table into the users and groups tables.
func (*TestContext) DBItemsAncestorsAndPermissionsAreComputed ¶
func (ctx *TestContext) DBItemsAncestorsAndPermissionsAreComputed() error
DBItemsAncestorsAndPermissionsAreComputed computes the items_ancestors and permissions_generated tables.
func (*TestContext) DBTimeNow ¶ added in v2.21.4
func (ctx *TestContext) DBTimeNow(timeStrRaw string) error
DBTimeNow sets the current time in the database to the provided time.
func (*TestContext) FalsifiedSignedTokenIsDistributed ¶
func (ctx *TestContext) FalsifiedSignedTokenIsDistributed( varName, signerName string, jsonPayload *godog.DocString, ) error
FalsifiedSignedTokenIsDistributed generates a falsified token and sets it in a global template variable.
func (*TestContext) GroupHasGrantViewPermissionOnItem ¶ added in v2.23.0
func (ctx *TestContext) GroupHasGrantViewPermissionOnItem(viewValue, group, item string) error
GroupHasGrantViewPermissionOnItem gives a group a "grant_view" permission on an item with source_group_id=group and origin="group_membership".
func (*TestContext) GroupHasValidatedResultOnItem ¶ added in v2.23.0
func (ctx *TestContext) GroupHasValidatedResultOnItem(group, item string) error
GroupHasValidatedResultOnItem adds a validated result of the group on the item to the database.
func (*TestContext) GroupHasViewPermissionOnItem ¶ added in v2.23.0
func (ctx *TestContext) GroupHasViewPermissionOnItem(group, viewPermissionValue, item string) error
GroupHasViewPermissionOnItem gives a group a "view" permission on an item with source_group_id=group and origin="group_membership".
func (*TestContext) GroupHasWatchPermissionOnItem ¶ added in v2.23.0
func (ctx *TestContext) GroupHasWatchPermissionOnItem(group, watchValue, item string) error
GroupHasWatchPermissionOnItem gives a group a "watch" permission on an item with source_group_id=group and origin="group_membership".
func (*TestContext) GroupIsAChildOfTheGroup ¶
func (ctx *TestContext) GroupIsAChildOfTheGroup(childGroup, parentGroup string) error
GroupIsAChildOfTheGroup puts a group as a child of another group.
func (*TestContext) GroupIsAManagerOfTheGroupAndCanGrantGroupAccess ¶ added in v2.23.0
func (ctx *TestContext) GroupIsAManagerOfTheGroupAndCanGrantGroupAccess(managerGroup, group string) error
GroupIsAManagerOfTheGroupAndCanGrantGroupAccess sets the group as a manager of the given group with can_grant_group_access permission.
func (*TestContext) GroupIsAManagerOfTheGroupAndCanManageMembershipsAndGroup ¶ added in v2.23.0
func (ctx *TestContext) GroupIsAManagerOfTheGroupAndCanManageMembershipsAndGroup(managerGroup, group string) error
GroupIsAManagerOfTheGroupAndCanManageMembershipsAndGroup sets the group as a manager of the group with the can_manage=memberships_and_groups permission.
func (*TestContext) GroupIsAManagerOfTheGroupAndCanWatchItsMembers ¶ added in v2.23.0
func (ctx *TestContext) GroupIsAManagerOfTheGroupAndCanWatchItsMembers(managerGroup, group string) error
GroupIsAManagerOfTheGroupAndCanWatchItsMembers sets the user as a manager of the group with can_watch_members permission.
func (*TestContext) GroupIsAMemberOfTheGroup ¶ added in v2.23.0
func (ctx *TestContext) GroupIsAMemberOfTheGroup(childGroupName, parentGroupName string)
GroupIsAMemberOfTheGroup Puts a group into a group.
func (*TestContext) IAmAManagerOfTheGroup ¶
func (ctx *TestContext) IAmAManagerOfTheGroup(group string) error
IAmAManagerOfTheGroup sets the current user as a manager of the given group with can_watch_members=false.
func (*TestContext) IAmAManagerOfTheGroupAndCanWatchItsMembers ¶
func (ctx *TestContext) IAmAManagerOfTheGroupAndCanWatchItsMembers(group string) error
IAmAManagerOfTheGroupAndCanWatchItsMembers adds the permission for the current user to watch a group.
func (*TestContext) IAmAManagerOfTheGroupWithID ¶
func (ctx *TestContext) IAmAManagerOfTheGroupWithID(group string) error
IAmAManagerOfTheGroupWithID sets the current user as a manager of a group with an id.
func (*TestContext) IAmAMemberOfTheGroup ¶
func (ctx *TestContext) IAmAMemberOfTheGroup(name string) error
IAmAMemberOfTheGroup puts a user in a group.
func (*TestContext) IAmAMemberOfTheGroupWithID ¶
func (ctx *TestContext) IAmAMemberOfTheGroupWithID(group string) error
IAmAMemberOfTheGroupWithID creates a group and add the user in it.
func (*TestContext) IAmPartOfTheHelperGroupOfTheThread ¶
func (ctx *TestContext) IAmPartOfTheHelperGroupOfTheThread() error
IAmPartOfTheHelperGroupOfTheThread states that user is a member of the helper group, of a given thread.
func (*TestContext) IAmUserWithID ¶
func (ctx *TestContext) IAmUserWithID(userID int64) error
IAmUserWithID sets the current logged user to the one with the provided ID.
func (*TestContext) ICanRequestHelpToTheGroupWithIDOnTheItemWithID ¶
func (ctx *TestContext) ICanRequestHelpToTheGroupWithIDOnTheItemWithID(group, item string) error
ICanRequestHelpToTheGroupWithIDOnTheItemWithID gives the user the permission to request help from a given group to a given item.
func (*TestContext) IHavePermissionOnItem ¶ added in v2.23.0
func (ctx *TestContext) IHavePermissionOnItem(permType, permValue, item string) error
IHavePermissionOnItem gives the current user a permission on an item with source_group_id=user and origin="group_membership".
func (*TestContext) IHaveValidatedResultOnItem ¶ added in v2.23.0
func (ctx *TestContext) IHaveValidatedResultOnItem(item string) error
IHaveValidatedResultOnItem states that the current user has a validated result on the item.
func (*TestContext) IHaveViewPermissionOnItem ¶ added in v2.23.0
func (ctx *TestContext) IHaveViewPermissionOnItem(viewValue, item string) error
IHaveViewPermissionOnItem gives the current user a "view" permission on an item with source_group_id=user and origin="group_membership".
func (*TestContext) IHaveWatchPermissionOnItem ¶ added in v2.23.0
func (ctx *TestContext) IHaveWatchPermissionOnItem(watchValue, item string) error
IHaveWatchPermissionOnItem gives the current user a "watch" permission on an item with source_group_id=user and origin="group_membership".
func (*TestContext) ISendrequestTo ¶
func (ctx *TestContext) ISendrequestTo(method string, path string) error
func (*TestContext) ISendrequestToWithBody ¶
func (*TestContext) ItShouldBeAJSONArrayWithEntries ¶
func (ctx *TestContext) ItShouldBeAJSONArrayWithEntries(count int) error
func (*TestContext) LogsShouldContain ¶
func (ctx *TestContext) LogsShouldContain(docString *godog.DocString) error
LogsShouldContain checks that the logs contain a provided string.
func (*TestContext) ScenarioTeardown ¶
func (ctx *TestContext) ScenarioTeardown(*godog.Scenario, error)
ScenarioTeardown is called after each scenario to remove stubs.
func (*TestContext) ServerTimeIsFrozen ¶ added in v2.23.0
func (ctx *TestContext) ServerTimeIsFrozen() error
ServerTimeIsFrozen stubs time.Now with the current time.
func (*TestContext) ServerTimeNow ¶ added in v2.23.0
func (ctx *TestContext) ServerTimeNow(timeStr string) error
ServerTimeNow stubs time.Now with the provided time.
func (*TestContext) SetGroupPermissionOnItem ¶ added in v2.23.0
func (ctx *TestContext) SetGroupPermissionOnItem(permission, value, group, item string) error
SetGroupPermissionOnItem grants a group a permission on an item with source_group_id=group and origin="group_membership".
func (*TestContext) SetGroupPermissionWithSourceGroupAndOriginOnItem ¶ added in v2.23.0
func (ctx *TestContext) SetGroupPermissionWithSourceGroupAndOriginOnItem(permission, value, group, item, sourceGroup, origin string) error
SetGroupPermissionWithSourceGroupAndOriginOnItem gives a group a permission on an item with a specific source_group and origin.
func (*TestContext) SetupTestContext ¶
func (ctx *TestContext) SetupTestContext(sc *godog.Scenario)
SetupTestContext initializes the test context. Called before each scenario.
func (*TestContext) SignedTokenIsDistributed ¶
func (ctx *TestContext) SignedTokenIsDistributed( varName, signerName string, jsonPayload *godog.DocString, ) error
SignedTokenIsDistributed declares a signed token and puts it in a global variable. This allows later use inside a request, or a comparison with a response.
func (*TestContext) TableAtColumnValueShouldBe ¶
func (ctx *TestContext) TableAtColumnValueShouldBe( tableName, columnName, columnValues string, data *godog.Table, ) error
TableAtColumnValueShouldBe verifies that the rows of the DB table having the provided values in the specified column match the provided data.
func (*TestContext) TableAtColumnValueShouldBeEmpty ¶
func (ctx *TestContext) TableAtColumnValueShouldBeEmpty(tableName, columnName, valuesStr string) error
TableAtColumnValueShouldBeEmpty verifies that the DB table does not contain rows having the provided values in the specified column.
func (*TestContext) TableShouldBe ¶
func (ctx *TestContext) TableShouldBe(tableName string, data *godog.Table) error
TableShouldBe verifies that the DB table matches the provided data.
func (*TestContext) TableShouldBeEmpty ¶
func (ctx *TestContext) TableShouldBeEmpty(tableName string) error
TableShouldBeEmpty verifies that the DB table is empty.
func (*TestContext) TableShouldNotContainColumnValue ¶
func (ctx *TestContext) TableShouldNotContainColumnValue( tableName, columnName, columnValues string, ) error
TableShouldNotContainColumnValue verifies that the DB table does not contain rows having the provided values in the specified column.
func (*TestContext) TableShouldStayUnchanged ¶
func (ctx *TestContext) TableShouldStayUnchanged(tableName string) error
TableShouldStayUnchanged checks that the DB table has not changed.
func (*TestContext) TableShouldStayUnchangedButTheRowWithColumnValue ¶
func (ctx *TestContext) TableShouldStayUnchangedButTheRowWithColumnValue(tableName, columnName, columnValues string) error
TableShouldStayUnchangedButTheRowWithColumnValue checks that the DB table has not changed except for rows with the specified values in the specified column.
func (*TestContext) TableShouldStayUnchangedButTheRowsWithColumnValueShouldBeDeleted ¶
func (ctx *TestContext) TableShouldStayUnchangedButTheRowsWithColumnValueShouldBeDeleted( tableName, columnNames, columnValues string, ) error
TableShouldStayUnchangedButTheRowsWithColumnValueShouldBeDeleted checks for row deletion.
func (*TestContext) TheApplicationConfigIs ¶
func (ctx *TestContext) TheApplicationConfigIs(yamlConfig *godog.DocString) error
TheApplicationConfigIs specifies variables of the app configuration given in YAML format.
func (*TestContext) TheContextVariableIs ¶
func (ctx *TestContext) TheContextVariableIs(variableName, value string) error
TheContextVariableIs sets a context variable in the request http.Request as the provided value. Can be retrieved from the request with r.Context().Value(service.APIServiceContextVariableName("variableName")).
func (*TestContext) TheFieldOfTheGroupShouldBe ¶
func (ctx *TestContext) TheFieldOfTheGroupShouldBe(field, group, value string) error
TheFieldOfTheGroupShouldBe checks that the field of a group in the database is equal to a value.
func (*TestContext) TheGeneratedAuthKeyIs ¶
func (ctx *TestContext) TheGeneratedAuthKeyIs(generatedKey string) error
TheGeneratedAuthKeyIs stubs auth.GenerateKey to return the provided auth key instead of a random one.
func (*TestContext) TheGeneratedGroupCodeIs ¶
func (ctx *TestContext) TheGeneratedGroupCodeIs(generatedCode string) error
TheGeneratedGroupCodeIs stubs groups.GenerateGroupCode to return the provided code instead of a random one.
func (*TestContext) TheGeneratedGroupCodesAre ¶
func (ctx *TestContext) TheGeneratedGroupCodesAre(generatedCodes string) error
TheGeneratedGroupCodesAre stubs groups.GenerateGroupCode to generate the provided codes instead of random ones. generatedCodes is in the following form: example for three codes: "code1","code2","code3" with an arbitrary number of codes.
func (*TestContext) TheLoginModuleAccountEndpointForTokenReturns ¶
func (ctx *TestContext) TheLoginModuleAccountEndpointForTokenReturns( authToken string, statusCode int, body *godog.DocString, ) error
TheLoginModuleAccountEndpointForTokenReturns mocks the return of the login module /user_api/account with the provided authorization token.
func (*TestContext) TheLoginModuleCreateEndpointWithParamsReturns ¶
func (ctx *TestContext) TheLoginModuleCreateEndpointWithParamsReturns( params string, statusCode int, body *godog.DocString, ) error
TheLoginModuleCreateEndpointWithParamsReturns mocks the return of the login module /platform_api/accounts_manager/create with the provided parameters, return status, and body.
func (*TestContext) TheLoginModuleDeleteEndpointWithParamsReturns ¶
func (ctx *TestContext) TheLoginModuleDeleteEndpointWithParamsReturns( params string, statusCode int, body *godog.DocString, ) error
TheLoginModuleDeleteEndpointWithParamsReturns mocks the return of the login module /platform_api/accounts_manager/delete with the provided parameters, return status, and body.
func (*TestContext) TheLoginModuleLTIResultSendEndpointForUserIDContentIDScoreReturns ¶
func (ctx *TestContext) TheLoginModuleLTIResultSendEndpointForUserIDContentIDScoreReturns( userID, contentID, score string, statusCode int, body *godog.DocString, ) error
TheLoginModuleLTIResultSendEndpointForUserIDContentIDScoreReturns mocks the return of the login module /platform_api/lti_result/send with the provided user_id, content_id, and score.
func (*TestContext) TheLoginModuleTokenEndpointForCodeAndCodeVerifierAndRedirectURIReturns ¶
func (ctx *TestContext) TheLoginModuleTokenEndpointForCodeAndCodeVerifierAndRedirectURIReturns( code, codeVerifier, redirectURI string, statusCode int, body *godog.DocString, ) error
TheLoginModuleTokenEndpointForCodeAndCodeVerifierAndRedirectURIReturns mocks the return of the login module /oauth/token, called with the provided code, code_verifier, and redirect_uri.
func (*TestContext) TheLoginModuleTokenEndpointForCodeAndCodeVerifierReturns ¶
func (ctx *TestContext) TheLoginModuleTokenEndpointForCodeAndCodeVerifierReturns( code, codeVerifier string, statusCode int, body *godog.DocString, ) error
TheLoginModuleTokenEndpointForCodeAndCodeVerifierReturns mocks the return of the login module /oauth/token, called with the provided code and code_verifier.
func (*TestContext) TheLoginModuleTokenEndpointForCodeReturns ¶
func (ctx *TestContext) TheLoginModuleTokenEndpointForCodeReturns( code string, statusCode int, body *godog.DocString, ) error
TheLoginModuleTokenEndpointForCodeReturns mocks the return of the login module /oauth/token, called with a provided code.
func (*TestContext) TheLoginModuleTokenEndpointForRefreshTokenReturns ¶
func (ctx *TestContext) TheLoginModuleTokenEndpointForRefreshTokenReturns( refreshToken string, statusCode int, body *godog.DocString, ) error
TheLoginModuleTokenEndpointForRefreshTokenReturns mocks the return of the login module /oauth/token, called with the provided refresh_token.
func (*TestContext) TheLoginModuleUnlinkClientEndpointForUserIDReturns ¶
func (ctx *TestContext) TheLoginModuleUnlinkClientEndpointForUserIDReturns( userID string, statusCode int, body *godog.DocString, ) error
TheLoginModuleUnlinkClientEndpointForUserIDReturns mocks the return of the login module /platform_api/accounts_manager/unlink_client with the provided user_id.
func (*TestContext) TheRequestHeaderIs ¶
func (ctx *TestContext) TheRequestHeaderIs(name, value string) error
func (*TestContext) TheResponseAtInJSONShouldBe ¶
func (ctx *TestContext) TheResponseAtInJSONShouldBe(jsonPath string, wants *godog.DocString) error
TheResponseAtInJSONShouldBe checks that the response in JSON at a JSONPath matches.
func (*TestContext) TheResponseAtShouldBe ¶
func (ctx *TestContext) TheResponseAtShouldBe(jsonPath string, wants *godog.Table) error
TheResponseAtShouldBe checks that the response at a JSONPath matches multiple values.
func (*TestContext) TheResponseAtShouldBeTheBase64OfAnAES256GCMEncryptedJSONObjectContaining ¶
func (ctx *TestContext) TheResponseAtShouldBeTheBase64OfAnAES256GCMEncryptedJSONObjectContaining( jsonPath string, expectedJSONParam *godog.DocString, ) error
TheResponseAtShouldBeTheBase64OfAnAES256GCMEncryptedJSONObjectContaining checks that the response at a JSONPath is an AES256GCM encrypted JSON object.
func (*TestContext) TheResponseAtShouldBeTheValue ¶
func (ctx *TestContext) TheResponseAtShouldBeTheValue(jsonPath, value string) error
TheResponseAtShouldBeTheValue checks that the response at a JSONPath is a certain value.
func (*TestContext) TheResponseBodyShouldBe ¶
func (ctx *TestContext) TheResponseBodyShouldBe(body *godog.DocString) (err error)
TheResponseBodyShouldBe checks that the response is the same as the one provided.
func (*TestContext) TheResponseBodyShouldBeJSON ¶
func (ctx *TestContext) TheResponseBodyShouldBeJSON(body *godog.DocString) (err error)
func (*TestContext) TheResponseCodeShouldBe ¶
func (ctx *TestContext) TheResponseCodeShouldBe(code int) error
func (*TestContext) TheResponseDecodedBodyShouldBeJSON ¶
func (ctx *TestContext) TheResponseDecodedBodyShouldBeJSON(responseType string, body *godog.DocString) (err error)
func (*TestContext) TheResponseErrorMessageShouldContain ¶
func (ctx *TestContext) TheResponseErrorMessageShouldContain(s string) (err error)
TheResponseErrorMessageShouldContain checks that the response contains the provided string.
func (*TestContext) TheResponseHeaderShouldBe ¶
func (ctx *TestContext) TheResponseHeaderShouldBe(headerName, headerValue string) (err error)
TheResponseHeaderShouldBe checks that the response header matches the provided value.
func (*TestContext) TheResponseHeaderShouldNotBeSet ¶
func (ctx *TestContext) TheResponseHeaderShouldNotBeSet(headerName string) (err error)
TheResponseHeaderShouldNotBeSet checks that the response header is not set.
func (*TestContext) TheResponseHeadersShouldBe ¶
func (ctx *TestContext) TheResponseHeadersShouldBe( headerName string, headersValue *godog.DocString, ) (err error)
TheResponseHeadersShouldBe checks that the response header matches the multiline provided value.
func (*TestContext) TheResponseShouldBe ¶
func (ctx *TestContext) TheResponseShouldBe(kind string) error
TheResponseShouldBe checks that the response status of the response is of the given kind.
func (*TestContext) TheTemplateConstantIsDocString ¶
func (ctx *TestContext) TheTemplateConstantIsDocString(name string, value *godog.DocString) error
func (*TestContext) TheTemplateConstantIsString ¶
func (ctx *TestContext) TheTemplateConstantIsString(name, value string) error
func (*TestContext) ThereAreCountAccessTokensForUser ¶
func (ctx *TestContext) ThereAreCountAccessTokensForUser(count int, user string) error
ThereAreCountAccessTokensForUser checks if there are a given number of access tokens for a given user.
func (*TestContext) ThereAreCountSessionsForUser ¶
func (ctx *TestContext) ThereAreCountSessionsForUser(count int, user string) error
ThereAreCountSessionsForUser checks if there are a given number of sessions for a given user.
func (*TestContext) ThereAreTheFollowingAccessTokens ¶
func (ctx *TestContext) ThereAreTheFollowingAccessTokens(accessTokens *godog.Table) error
ThereAreTheFollowingAccessTokens create access tokens.
func (*TestContext) ThereAreTheFollowingGroupPendingRequests ¶
func (ctx *TestContext) ThereAreTheFollowingGroupPendingRequests(entries *godog.Table) error
ThereAreTheFollowingGroupPendingRequests adds the group pending requests in the database.
func (*TestContext) ThereAreTheFollowingGroups ¶
func (ctx *TestContext) ThereAreTheFollowingGroups(groups *godog.Table) error
ThereAreTheFollowingGroups defines groups.
func (*TestContext) ThereAreTheFollowingItemPermissions ¶
func (ctx *TestContext) ThereAreTheFollowingItemPermissions(itemPermissions *godog.Table) error
ThereAreTheFollowingItemPermissions defines item permissions.
func (*TestContext) ThereAreTheFollowingItemRelations ¶
func (ctx *TestContext) ThereAreTheFollowingItemRelations(itemPermissions *godog.Table) error
ThereAreTheFollowingItemRelations defines item relations, in items_items table.
func (*TestContext) ThereAreTheFollowingItems ¶
func (ctx *TestContext) ThereAreTheFollowingItems(items *godog.Table) error
ThereAreTheFollowingItems defines items.
func (*TestContext) ThereAreTheFollowingSessions ¶
func (ctx *TestContext) ThereAreTheFollowingSessions(sessions *godog.Table) error
ThereAreTheFollowingSessions create sessions.
func (*TestContext) ThereAreTheFollowingTasks ¶
func (ctx *TestContext) ThereAreTheFollowingTasks(tasks *godog.Table) error
ThereAreTheFollowingTasks defines item tasks.
func (*TestContext) ThereAreTheFollowingThreads ¶
func (ctx *TestContext) ThereAreTheFollowingThreads(threads *godog.Table) error
ThereAreTheFollowingThreads create threads.
func (*TestContext) ThereAreTheFollowingUsers ¶
func (ctx *TestContext) ThereAreTheFollowingUsers(users *godog.Table) error
ThereAreTheFollowingUsers defines users.
func (*TestContext) ThereAreTheFollowingValidatedResults ¶ added in v2.23.0
func (ctx *TestContext) ThereAreTheFollowingValidatedResults(results *godog.Table) error
ThereAreTheFollowingValidatedResults creates validated results described in the given Godog table.
func (*TestContext) ThereIsAGroup ¶
func (ctx *TestContext) ThereIsAGroup(group string) error
ThereIsAGroup creates a new group (type=Class).
func (*TestContext) ThereIsATeam ¶ added in v2.23.0
func (ctx *TestContext) ThereIsATeam(group string) error
ThereIsATeam creates a new team.
func (*TestContext) ThereIsAThreadWith ¶
func (ctx *TestContext) ThereIsAThreadWith(parameters string) error
ThereIsAThreadWith creates a thread.
func (*TestContext) ThereIsAUser ¶
func (ctx *TestContext) ThereIsAUser(name string) error
ThereIsAUser create a user.
func (*TestContext) ThereIsNoAccessToken ¶
func (ctx *TestContext) ThereIsNoAccessToken(accessToken string) error
ThereIsNoAccessToken checks that an access token doesn't exist.
func (*TestContext) ThereIsNoSessionID ¶
func (ctx *TestContext) ThereIsNoSessionID(session string) error
ThereIsNoSessionID checks that a session with given session ID doesn't exist.
func (*TestContext) ThereIsNoThreadWith ¶
func (ctx *TestContext) ThereIsNoThreadWith(parameters string) error
ThereIsNoThreadWith states that a given thread doesn't exist.
func (*TestContext) ThereShouldBeNoGroupPendingRequestsForTheGroupWithTheType ¶
func (ctx *TestContext) ThereShouldBeNoGroupPendingRequestsForTheGroupWithTheType(group, requestType string) error
ThereShouldBeNoGroupPendingRequestsForTheGroupWithTheType checks that no rows are present in the group_pending_requests table.
func (*TestContext) ThereShouldBeNoGroupPendingRequestsForTheMemberWithTheType ¶
func (ctx *TestContext) ThereShouldBeNoGroupPendingRequestsForTheMemberWithTheType(member, requestType string) error
ThereShouldBeNoGroupPendingRequestsForTheMemberWithTheType checks that no rows are present in the group_pending_requests table.
func (*TestContext) ThereShouldBeTheFollowingGroupMembershipChanges ¶
func (ctx *TestContext) ThereShouldBeTheFollowingGroupMembershipChanges(entries *godog.Table) error
ThereShouldBeTheFollowingGroupMembershipChanges checks that rows are present in the group_membership_changes table of the database.
func (*TestContext) ThereShouldBeTheFollowingGroupPendingRequests ¶
func (ctx *TestContext) ThereShouldBeTheFollowingGroupPendingRequests(entries *godog.Table) error
ThereShouldBeTheFollowingGroupPendingRequests checks that rows are present in the group_pending_requests table of the database.
func (*TestContext) TimeIsFrozen ¶
func (ctx *TestContext) TimeIsFrozen() error
TimeIsFrozen stubs time.Now with the current time and mocks the DB function NOW().
func (*TestContext) TimeNow ¶
func (ctx *TestContext) TimeNow(timeStr string) error
TimeNow stubs time.Now and mocks the DB function NOW() with the provided time.
func (*TestContext) UserCanRequestHelpToOnItem ¶ added in v2.23.0
func (ctx *TestContext) UserCanRequestHelpToOnItem(helperGroup, user, item string) error
UserCanRequestHelpToOnItem sets the can_request_help_to permission.
func (*TestContext) UserIsAMemberOfTheGroup ¶
func (ctx *TestContext) UserIsAMemberOfTheGroup(user, group string) error
UserIsAMemberOfTheGroup puts a user in a group.
func (*TestContext) UserIsAMemberOfTheGroupWhoHasApprovedAccessToHisPersonalInfo ¶
func (ctx *TestContext) UserIsAMemberOfTheGroupWhoHasApprovedAccessToHisPersonalInfo(user, group string) error
UserIsAMemberOfTheGroupWhoHasApprovedAccessToHisPersonalInfo puts a user in a group with approved access to his personnel info.
func (*TestContext) UserIsOwnerOfItem ¶ added in v2.23.0
func (ctx *TestContext) UserIsOwnerOfItem(isOwner, user, item string) error
UserIsOwnerOfItem sets the is_owner permission.
func (*TestContext) UserShouldBeAMemberOfTheGroup ¶
func (ctx *TestContext) UserShouldBeAMemberOfTheGroup(user, group string) error
UserShouldBeAMemberOfTheGroup checks that the user is a member of the group.
func (*TestContext) UserShouldNotBeAMemberOfTheGroup ¶
func (ctx *TestContext) UserShouldNotBeAMemberOfTheGroup(user, group string) error
UserShouldNotBeAMemberOfTheGroup checks that the user is not a member of the group.
Source Files ¶
- app_language_db.go
- app_language_group_membership_changes.go
- app_language_group_pending_requests.go
- app_language_groups.go
- app_language_sessions.go
- app_language_users.go
- db.go
- db_time.go
- feature_context.go
- http.go
- known_types.go
- loader.go
- propagation_verifier.go
- steps_app_language.go
- steps_db.go
- steps_loginmodule.go
- steps_misc.go
- steps_request.go
- steps_response.go
- steps_template.go
- suppress_output.go
- template.go
- test_context.go
- threads.go