Browse Source

fix(systemtags): Add one unittest for to test tags parsing after the dependency was updated

Signed-off-by: Ferdinand Thiessen <opensource@fthiessen.de>
tags/v28.0.0beta1
Ferdinand Thiessen 7 months ago
parent
commit
4c49dda128

+ 105
- 0
apps/systemtags/src/utils.spec.ts View File

@@ -0,0 +1,105 @@
/**
* @copyright 2023 Ferdinand Thiessen <opensource@fthiessen.de>
*
* @author Ferdinand Thiessen <opensource@fthiessen.de>
*
* @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 type { DAVResultResponseProps } from 'webdav'
import type { ServerTag, Tag } from './types.js'

import { describe, it, expect } from '@jest/globals'
import { formatTag, parseIdFromLocation, parseTags } from './utils'

describe('systemtags - utils', () => {
describe('parseTags', () => {
it('renames properties', () => {
const tags = parseTags([{
props: {
displayname: 'display-name',
resourcetype: {
collection: false,
},
'user-visible': true,
'user-assignable': true,
'can-assign': true,
} as DAVResultResponseProps,
}])

expect(tags).toEqual([
{
displayname: 'display-name',
resourcetype: {
collection: false,
},
userVisible: true,
userAssignable: true,
canAssign: true,
},
])
})
})

describe('parseIdFromLocation', () => {
it('works with simple url', () => {
const url = 'http://some.domain/remote.php/dav/3'
expect(parseIdFromLocation(url)).toEqual(3)
})
it('works with trailing slash', () => {
const url = 'http://some.domain/remote.php/dav/3/'
expect(parseIdFromLocation(url)).toEqual(3)
})
it('works with query', () => {
const url = 'http://some.domain/remote.php/dav/3?some-value'
expect(parseIdFromLocation(url)).toEqual(3)
})
})

describe('formatTag', () => {
it('handles tags', () => {
const tag: Tag = {
canAssign: true,
displayName: 'DisplayName',
userAssignable: true,
userVisible: true,
}

expect(formatTag(tag)).toEqual({
canAssign: true,
name: 'DisplayName',
userAssignable: true,
userVisible: true,
})
})
it('handles server tags', () => {
const tag: ServerTag = {
canAssign: true,
name: 'DisplayName',
userAssignable: true,
userVisible: true,
}

expect(formatTag(tag)).toEqual({
canAssign: true,
name: 'DisplayName',
userAssignable: true,
userVisible: true,
})
})
})
})

+ 4
- 3
apps/systemtags/src/utils.ts View File

@@ -22,19 +22,20 @@

import camelCase from 'camelcase'

import type { FileStat } from 'webdav'
import type { DAVResultResponseProps } from 'webdav'

import type { ServerTag, Tag, TagWithId } from './types.js'

export const parseTags = (tags: Required<FileStat>[]): TagWithId[] => {
export const parseTags = (tags: { props: DAVResultResponseProps }[]): TagWithId[] => {
return tags.map(({ props }) => Object.fromEntries(
Object.entries(props)
.map(([key, value]) => [camelCase(key), value])
.map(([key, value]) => [camelCase(key), value]),
)) as TagWithId[]
}

/**
* Parse id from `Content-Location` header
* @param url URL to parse
*/
export const parseIdFromLocation = (url: string): number => {
const queryPos = url.indexOf('?')

+ 2
- 2
dist/files-sidebar.js
File diff suppressed because it is too large
View File


+ 1
- 1
dist/files-sidebar.js.map
File diff suppressed because it is too large
View File


+ 2
- 2
dist/icons.css View File

@@ -19,8 +19,8 @@
--original-icon-category-auth-white: url();
--original-icon-category-customization-dark: url();
--original-icon-category-customization-white: url();
--original-icon-category-dashboard-dark: url();
--original-icon-category-dashboard-white: url();
--original-icon-category-dashboard-dark: url();
--original-icon-category-dashboard-white: url();
--original-icon-category-files-dark: url();
--original-icon-category-files-white: url();
--original-icon-category-games-dark: url();

+ 2
- 2
dist/systemtags-init.js
File diff suppressed because it is too large
View File


+ 1
- 1
dist/systemtags-init.js.map
File diff suppressed because it is too large
View File


+ 1
- 0
jest.config.ts View File

@@ -28,6 +28,7 @@ const ignorePatterns = [
'@mdi/svg',
'@nextcloud/vue',
'ansi-regex',
'camelcase',
'char-regex',
'hot-patcher',
'is-svg',

Loading…
Cancel
Save