Skip to content

Commit

Permalink
Added e2e tests for full text search
Browse files Browse the repository at this point in the history
  • Loading branch information
grgprarup committed Jun 15, 2023
1 parent 391f918 commit ddc80fb
Show file tree
Hide file tree
Showing 9 changed files with 251 additions and 9 deletions.
102 changes: 102 additions & 0 deletions tests/e2e/cucumber/features/smoke/fullTextSearch.ocis.feature
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
Feature: Search
As a user
I want to do full text search
So that I can find the files with the content I am looking for

Background:
Given "Admin" creates following users using API
| id |
| Alice |
| Brian |
And "Admin" sets the default folder for received shares to "Shares"
And "Admin" disables share auto accepting
And "Admin" assigns following roles to the users using API
| id | role |
| Brian | Space Admin |

And "Alice" logs in
And "Alice" creates the following folder in personal space using API
| name |
| folderToShare |
And "Alice" uploads the following local file into personal space using API
| localFile | to |
| filesForUpload/textfile.txt | folderToShare/fileToShare.txt |
And "Alice" shares the following resource using API
| resource | recipient | type | role |
| folderToShare | Brian | user | Can edit |

And "Brian" logs in
And "Brian" accepts the following share using API
| name |
| folderToShare |
And "Brian" creates the following folder in personal space using API
| name |
| testFolder |
And "Brian" uploads the following local file into personal space using API
| localFile | to |
| filesForUpload/textfile.txt | textfile.txt |
| filesForUpload/textfile.txt | fileWithTag.txt |
| filesForUpload/textfile.txt | withTag.txt |
| filesForUpload/textfile.txt | testFolder/innerTextfile.txt |

And "Brian" creates the following project spaces using API
| name | id |
| FullTextSearch | fulltextsearch.1 |
And "Brian" creates the following folder in space "FullTextSearch" using API
| name |
| spaceFolder |
And "Brian" creates the following file in space "FullTextSearch" using API
| name | content |
| spaceFolder/spaceTextfile.txt | This is test file. |

And "Brian" opens the "files" app
# And "Brian" adds the following tags for the following resources using API
# | resource | tags |
# | fileWithTag.txt | tag 1 |
# | withTag.txt | tag 1 |
And "Brian" adds the following tags for the following resources using the sidebar panel
| resource | tags |
| fileWithTag.txt | tag 1 |
| withTag.txt | tag 1 |

Scenario: Search for content of file
And "Brian" opens the "files" app

When "Brian" searches "" using the global search bar
Then "Brian" should see the message "Search for files" on the webUI

When "Brian" selects tag "tag 1" from the search result filter chip
Then following resources should be displayed in the files list for user "Brian"
| resource |
| fileWithTag.txt |
| withTag.txt |

When "Brian" searches "file" using the global search bar
Then following resources should be displayed in the files list for user "Brian"
| resource |
| fileWithTag.txt |

When "Brian" clears tag filter
Then following resources should be displayed in the files list for user "Brian"
| resource |
| textfile.txt |
| fileWithTag.txt |
| testFolder/innerTextfile.txt |
| fileToShare.txt |
| spaceFolder/spaceTextfile.txt |

When "Brian" enables the option to search in file content
And "Brian" searches "Cheers" using the global search bar
Then following resources should be displayed in the files list for user "Brian"
| resource |
| textfile.txt |
| testFolder/innerTextfile.txt |
| fileToShare.txt |
| fileWithTag.txt |
| withTag.txt |

When "Brian" opens the following file in texteditor
| resource |
| textfile.txt |
Then "Brian" should see the message "No results found" on the webUI
And "Brian" logs out
19 changes: 19 additions & 0 deletions tests/e2e/cucumber/steps/api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -298,3 +298,22 @@ Given(
}
}
)

// Given(
// '{string} adds the following tags for the following resources using API',
// async function (
// this: World,
// stepUser: string,
// stepTable: DataTable
// ): Promise<void> {
// const user = this.usersEnvironment.getUser({ key: stepUser })
// for (const info of stepTable.hashes()) {
// await api.graph.addTagsToTheResource({
// user,
// shareWith: info.user,
// shareType: info.shareType,
// role: info.role
// })
// }
// }
// )
6 changes: 3 additions & 3 deletions tests/e2e/cucumber/steps/ui/resources.ts
Original file line number Diff line number Diff line change
Expand Up @@ -433,15 +433,15 @@ When(
)

When(
/^"([^"].*)" opens the following file(?:s)? in (mediaviewer|pdfviewer)$/,
/^"([^"].*)" opens the following file(?:s)? in (mediaviewer|pdfviewer|texteditor)$/,
async function (this: World, stepUser: string, actionType: string, stepTable: DataTable) {
const { page } = this.actorsEnvironment.getActor({ key: stepUser })
const resourceObject = new objects.applicationFiles.Resource({ page })

for (const info of stepTable.hashes()) {
await resourceObject.openFileInViewer({
await resourceObject.openFile({
name: info.resource,
actionType: actionType as 'mediaviewer' | 'pdfviewer'
actionType: actionType as 'mediaviewer' | 'pdfviewer' | 'texteditor'
})
}
}
Expand Down
47 changes: 47 additions & 0 deletions tests/e2e/cucumber/steps/ui/search.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import { When, Then } from '@cucumber/cucumber'
import { World } from '../../environment'
import { objects } from '../../../support'
import { expect } from '@playwright/test'

When(
'{string} searches {string} using the global search bar',
async function (this: World, stepUser: string, keyword: string): Promise<void> {
const { page } = this.actorsEnvironment.getActor({ key: stepUser })
const searchObject = new objects.applicationFiles.Search({ page })
await searchObject.fullTextSearch({ keyword })
}
)

Then(
'{string} should see the message {string} on the webUI',
async function (this: World, stepUser: string, message: string): Promise<void> {
const { page } = this.actorsEnvironment.getActor({ key: stepUser })
const searchObject = new objects.applicationFiles.Search({ page })
const actualMessage = await searchObject.getSearchResultMessage()
expect(actualMessage).toBe(message)
}
)

When(
'{string} selects tag {string} from the search result filter chip',
async function (this: World, stepUser: string, tag: string): Promise<void> {
const { page } = this.actorsEnvironment.getActor({ key: stepUser })
const searchObject = new objects.applicationFiles.Search({ page })
await searchObject.selectTagFilter({ tag })
}
)

When('{string} clears tag filter', async function (this: World, stepUser: string): Promise<void> {
const { page } = this.actorsEnvironment.getActor({ key: stepUser })
const searchObject = new objects.applicationFiles.Search({ page })
await searchObject.clearTagFilter()
})

When(
/^"([^"]*)" (enable|disable)s the option to search in file content?$/,
async function (this: World, stepUser: string, enableOrDisable: string): Promise<void> {
const { page } = this.actorsEnvironment.getActor({ key: stepUser })
const searchObject = new objects.applicationFiles.Search({ page })
await searchObject.toggleSearchInFileContent({ enableOrDisable })
}
)
1 change: 1 addition & 0 deletions tests/e2e/support/objects/app-files/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,4 @@ export { Resource } from './resource'
export { Share } from './share'
export { Spaces } from './spaces'
export { Trashbin } from './trashbin'
export { Search } from './search'
8 changes: 4 additions & 4 deletions tests/e2e/support/objects/app-files/resource/actions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ const checkBoxForTrashbin = `//*[@data-test-resource-path="%s"]//ancestor::tr//i
export const fileRow =
'//ancestor::*[(contains(@class, "oc-tile-card") or contains(@class, "oc-tbody-tr"))]'
export const resourceNameSelector =
':is(#files-space-table, .oc-tiles-item, #files-shared-with-me-accepted-section) [data-test-resource-name="%s"]'
':is(#files-space-table, .oc-tiles-item, #files-shared-with-me-accepted-section, .files-table) [data-test-resource-name="%s"]'
const breadcrumbResourceNameSelector =
'//span[contains(@class, "oc-breadcrumb-item-text") and text()="%s"]'
const addNewResourceButton = `#new-file-menu-btn`
Expand Down Expand Up @@ -1106,13 +1106,13 @@ export const removeTagsFromResource = async (args: resourceTagsArgs): Promise<vo
await sidebar.close({ page })
}

export interface openFileInViewerArgs {
export interface openFileArgs {
page: Page
name: string
actionType: 'mediaviewer' | 'pdfviewer'
actionType: 'mediaviewer' | 'pdfviewer' | 'texteditor'
}

export const openFileInViewer = async (args: openFileInViewerArgs): Promise<void> => {
export const openFile = async (args: openFileArgs): Promise<void> => {
const { page, name, actionType } = args

if (actionType === 'mediaviewer') {
Expand Down
4 changes: 2 additions & 2 deletions tests/e2e/support/objects/app-files/resource/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -201,8 +201,8 @@ export class Resource {
await po.editResources({ ...args, page: this.#page })
}

async openFileInViewer(args: Omit<po.openFileInViewerArgs, 'page'>): Promise<void> {
await po.openFileInViewer({ ...args, page: this.#page })
async openFile(args: Omit<po.openFileArgs, 'page'>): Promise<void> {
await po.openFile({ ...args, page: this.#page })
}

async addTags(args: Omit<po.resourceTagsArgs, 'page'>): Promise<void> {
Expand Down
43 changes: 43 additions & 0 deletions tests/e2e/support/objects/app-files/search/actions.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
import { Page } from 'playwright'
import util from 'util'

const globalSearchInputSelector = '.oc-search-input'
const searchResultMessageSelector = '//p[@class="oc-text-muted"]'
const selectTagDropdownSelector = '.files-search-filter-tags'
const tagFilterChipSelector = '//button[contains(@data-test-value,"%s")]'
const clearTagFilterSelector =
'//div[contains(@class,"files-search-filter-tags")]//button[contains(@class,"oc-filter-chip-clear")]'
const enableSearchInFileContentSelector =
'//div[contains(@class,"files-search-filter-full-text")]//button[contains(@class,"oc-filter-chip-button")]'
const disableSearchInFileContentSelector =
'//div[contains(@class,"files-search-filter-full-text")]//button[contains(@class,"oc-filter-chip-clear")]'

export interface fullTextSearchArgs {
keyword: string
page: Page
}

export const fullTextSearch = async (args: fullTextSearchArgs): Promise<void> => {
const { page, keyword } = args
await page.locator(globalSearchInputSelector).fill(keyword)
await page.keyboard.press('Enter')
}

export const getSearchResultMessage = async ({ page }): Promise<string> => {
return await page.locator(searchResultMessageSelector).innerText()
}

export const selectTagFilter = async ({ tag, page }): Promise<void> => {
await page.locator(selectTagDropdownSelector).click()
await page.locator(util.format(tagFilterChipSelector, tag)).click()
}

export const clearTagFilter = async ({ page }): Promise<void> => {
await page.locator(clearTagFilterSelector).click()
}

export const toggleSearchInFileContent = async ({ enableOrDisable, page }): Promise<void> => {
enableOrDisable === 'enable'
? await page.locator(enableSearchInFileContentSelector).click()
: await page.locator(disableSearchInFileContentSelector).click()
}
30 changes: 30 additions & 0 deletions tests/e2e/support/objects/app-files/search/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import { Page } from 'playwright'
import * as po from '../search/actions'

export class Search {
#page: Page

constructor({ page }: { page: Page }) {
this.#page = page
}

async fullTextSearch(args: Omit<po.fullTextSearchArgs, 'page'>): Promise<void> {
await po.fullTextSearch({ ...args, page: this.#page })
}

async getSearchResultMessage(): Promise<string> {
return await po.getSearchResultMessage({ page: this.#page })
}

async selectTagFilter({ tag: string }): Promise<void> {
await po.selectTagFilter({ tag: string, page: this.#page })
}

async clearTagFilter(): Promise<void> {
await po.clearTagFilter({ page: this.#page })
}

async toggleSearchInFileContent({ enableOrDisable: string }): Promise<void> {
await po.toggleSearchInFileContent({ enableOrDisable: string, page: this.#page })
}
}

0 comments on commit ddc80fb

Please sign in to comment.