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>
Ferdinand Thiessen 7 months ago
parent
commit
4c49dda128

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

@@ -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

@@ -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('?')

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


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


+ 2 - 2
dist/icons.css

@@ -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();

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


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


+ 1 - 0
jest.config.ts

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

Some files were not shown because too many files changed in this diff