mirror of https://github.com/nextcloud/server.git
parent
146e9eeb9f
commit
802d7e010d
@ -0,0 +1,22 @@
|
||||
/**
|
||||
* @copyright Copyright (c) 2023 Lucas Azevedo <lhs_azevedo@hotmail.com>
|
||||
*
|
||||
* @author Lucas Azevedo <lhs_azevedo@hotmail.com>
|
||||
*
|
||||
* @license AGPL-3.0-or-later
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Affero General Public License as
|
||||
* published by the Free Software Foundation, either version 3 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Affero General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Affero General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
*/
|
||||
export default {}
|
@ -0,0 +1,143 @@
|
||||
/**
|
||||
* @copyright Copyright (c) 2023 Lucas Azevedo <lhs_azevedo@hotmail.com>
|
||||
*
|
||||
* @author Lucas Azevedo <lhs_azevedo@hotmail.com>
|
||||
*
|
||||
* @license AGPL-3.0-or-later
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Affero General Public License as
|
||||
* published by the Free Software Foundation, either version 3 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Affero General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Affero General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
*/
|
||||
import { action } from './inlineSystemTagsAction'
|
||||
import { expect } from '@jest/globals'
|
||||
import { File, Permission, View, FileAction } from '@nextcloud/files'
|
||||
|
||||
const view = {
|
||||
id: 'files',
|
||||
name: 'Files',
|
||||
} as View
|
||||
|
||||
describe('Inline system tags action conditions tests', () => {
|
||||
test('Default values', () => {
|
||||
const file = new File({
|
||||
id: 1,
|
||||
source: 'https://cloud.domain.com/remote.php/dav/files/admin/foobar.txt',
|
||||
owner: 'admin',
|
||||
mime: 'text/plain',
|
||||
permissions: Permission.ALL,
|
||||
})
|
||||
|
||||
expect(action).toBeInstanceOf(FileAction)
|
||||
expect(action.id).toBe('system-tags')
|
||||
expect(action.displayName([file], view)).toBe('')
|
||||
expect(action.iconSvgInline([], view)).toBe('')
|
||||
expect(action.default).toBeUndefined()
|
||||
expect(action.enabled).toBeUndefined()
|
||||
expect(action.order).toBe(0)
|
||||
})
|
||||
})
|
||||
|
||||
describe('Inline system tags action render tests', () => {
|
||||
test('Render nothing when Node does not have system tags', async () => {
|
||||
const file = new File({
|
||||
id: 1,
|
||||
source: 'http://localhost/remote.php/dav/files/admin/foobar.txt',
|
||||
owner: 'admin',
|
||||
mime: 'text/plain',
|
||||
permissions: Permission.ALL,
|
||||
})
|
||||
|
||||
const result = await action.renderInline!(file, view)
|
||||
expect(result).toBeNull()
|
||||
})
|
||||
|
||||
test('Render a single system tag', async () => {
|
||||
const file = new File({
|
||||
id: 1,
|
||||
source: 'http://localhost/remote.php/dav/files/admin/foobar.txt',
|
||||
owner: 'admin',
|
||||
mime: 'text/plain',
|
||||
permissions: Permission.ALL,
|
||||
attributes: {
|
||||
'system-tags': {
|
||||
'system-tag': 'Confidential'
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
const result = await action.renderInline!(file, view)
|
||||
expect(result).toBeInstanceOf(HTMLElement)
|
||||
expect(result!.outerHTML).toBe(
|
||||
'<ul class="files-list__system-tags" aria-label="This file has the tag Confidential">' +
|
||||
'<li class="files-list__system-tag">Confidential</li>' +
|
||||
'</ul>'
|
||||
)
|
||||
})
|
||||
|
||||
test('Render two system tags', async () => {
|
||||
const file = new File({
|
||||
id: 1,
|
||||
source: 'http://localhost/remote.php/dav/files/admin/foobar.txt',
|
||||
owner: 'admin',
|
||||
mime: 'text/plain',
|
||||
permissions: Permission.ALL,
|
||||
attributes: {
|
||||
'system-tags': {
|
||||
'system-tag': [
|
||||
'Important',
|
||||
'Confidential'
|
||||
]
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
const result = await action.renderInline!(file, view)
|
||||
expect(result).toBeInstanceOf(HTMLElement)
|
||||
expect(result!.outerHTML).toBe(
|
||||
'<ul class="files-list__system-tags" aria-label="This file has the tags Important and Confidential">' +
|
||||
'<li class="files-list__system-tag">Important</li>' +
|
||||
'<li class="files-list__system-tag files-list__system-tag--more" title="Confidential">+1</li>' +
|
||||
'</ul>'
|
||||
)
|
||||
})
|
||||
|
||||
test('Render multiple system tags', async () => {
|
||||
const file = new File({
|
||||
id: 1,
|
||||
source: 'http://localhost/remote.php/dav/files/admin/foobar.txt',
|
||||
owner: 'admin',
|
||||
mime: 'text/plain',
|
||||
permissions: Permission.ALL,
|
||||
attributes: {
|
||||
'system-tags': {
|
||||
'system-tag': [
|
||||
'Important',
|
||||
'Confidential',
|
||||
'Secret',
|
||||
'Classified'
|
||||
]
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
const result = await action.renderInline!(file, view)
|
||||
expect(result).toBeInstanceOf(HTMLElement)
|
||||
expect(result!.outerHTML).toBe(
|
||||
'<ul class="files-list__system-tags" aria-label="This file has the tags Important, Confidential, Secret and Classified">' +
|
||||
'<li class="files-list__system-tag">Important</li>' +
|
||||
'<li class="files-list__system-tag files-list__system-tag--more" title="Confidential, Secret, Classified">+3</li>' +
|
||||
'</ul>'
|
||||
)
|
||||
})
|
||||
})
|
Loading…
Reference in New Issue