mirror of
https://github.com/langgenius/dify.git
synced 2026-03-01 22:08:41 +08:00
* test: adding some web tests (#27792) * feat: add validation to prevent saving empty opening statement in conversation opener modal (#27843) * fix(web): improve the consistency of the inputs-form UI (#27837) * fix(web): increase z-index of PortalToFollowElemContent (#27823) * fix: installation_id is missing when in tools page (#27849) * fix: avoid passing empty uniqueIdentifier to InstallFromMarketplace (#27802) Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> * test: create new test scripts and update some existing test scripts o… (#27850) * feat: change feedback to forum (#27862) * chore: translate i18n files and update type definitions (#27868) Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> * Fix/template transformer line number (#27867) Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> * bump vite to 6.4.1 (#27877) * Add WEAVIATE_GRPC_ENDPOINT as designed in weaviate migration guide (#27861) Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * Fix: correct DraftWorkflowApi.post response model (#27289) Signed-off-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix Version 2.0.0-beta.2: Chat annotations Api Error #25506 (#27206) Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> * fix jina reader creadential migration command (#27883) * fix agent putout the output of workflow-tool twice (#26835) (#27087) * fix jina reader transform (#27922) * fix: prevent fetch version info in enterprise edition (#27923) * fix(api): fix `VariablePool.get` adding unexpected keys to variable_dictionary (#26767) Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * refactor: implement tenant self queue for rag tasks (#27559) Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: -LAN- <laipz8200@outlook.com> * fix: bump brotli to 1.2.0 resloved CVE-2025-6176 (#27950) Signed-off-by: kenwoodjw <blackxin55+@gmail.com> --------- Signed-off-by: Yongtao Huang <yongtaoh2022@gmail.com> Signed-off-by: kenwoodjw <blackxin55+@gmail.com> Co-authored-by: aka James4u <smart.jamesjin@gmail.com> Co-authored-by: Novice <novice12185727@gmail.com> Co-authored-by: yangzheli <43645580+yangzheli@users.noreply.github.com> Co-authored-by: Elliott <105957288+Elliott-byte@users.noreply.github.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: johnny0120 <johnny0120@users.noreply.github.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: Gritty_dev <101377478+codomposer@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: wangjifeng <163279492+kk-wangjifeng@users.noreply.github.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Boris Polonsky <BorisPolonsky@users.noreply.github.com> Co-authored-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: Cursx <33718736+Cursx@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: Jyong <76649700+JohnJyong@users.noreply.github.com> Co-authored-by: red_sun <56100962+redSun64@users.noreply.github.com> Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: QuantumGhost <obelisk.reg+git@gmail.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: hj24 <huangjian@dify.ai> Co-authored-by: kenwoodjw <blackxin55+@gmail.com>
140 lines
3.7 KiB
TypeScript
140 lines
3.7 KiB
TypeScript
import { draft07Validator, forbidBooleanProperties } from './validators'
|
|
|
|
describe('Validators', () => {
|
|
describe('draft07Validator', () => {
|
|
it('should validate a valid JSON schema', () => {
|
|
const validSchema = {
|
|
type: 'object',
|
|
properties: {
|
|
name: { type: 'string' },
|
|
age: { type: 'number' },
|
|
},
|
|
}
|
|
const result = draft07Validator(validSchema)
|
|
expect(result.valid).toBe(true)
|
|
expect(result.errors).toHaveLength(0)
|
|
})
|
|
|
|
it('should invalidate schema with unknown type', () => {
|
|
const invalidSchema = {
|
|
type: 'invalid_type',
|
|
}
|
|
const result = draft07Validator(invalidSchema)
|
|
expect(result.valid).toBe(false)
|
|
expect(result.errors.length).toBeGreaterThan(0)
|
|
})
|
|
|
|
it('should validate nested schemas', () => {
|
|
const nestedSchema = {
|
|
type: 'object',
|
|
properties: {
|
|
user: {
|
|
type: 'object',
|
|
properties: {
|
|
name: { type: 'string' },
|
|
address: {
|
|
type: 'object',
|
|
properties: {
|
|
street: { type: 'string' },
|
|
city: { type: 'string' },
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
const result = draft07Validator(nestedSchema)
|
|
expect(result.valid).toBe(true)
|
|
})
|
|
|
|
it('should validate array schemas', () => {
|
|
const arraySchema = {
|
|
type: 'array',
|
|
items: { type: 'string' },
|
|
}
|
|
const result = draft07Validator(arraySchema)
|
|
expect(result.valid).toBe(true)
|
|
})
|
|
})
|
|
|
|
describe('forbidBooleanProperties', () => {
|
|
it('should return empty array for schema without boolean properties', () => {
|
|
const schema = {
|
|
properties: {
|
|
name: { type: 'string' },
|
|
age: { type: 'number' },
|
|
},
|
|
}
|
|
const errors = forbidBooleanProperties(schema)
|
|
expect(errors).toHaveLength(0)
|
|
})
|
|
|
|
it('should detect boolean property at root level', () => {
|
|
const schema = {
|
|
properties: {
|
|
name: true,
|
|
age: { type: 'number' },
|
|
},
|
|
}
|
|
const errors = forbidBooleanProperties(schema)
|
|
expect(errors).toHaveLength(1)
|
|
expect(errors[0]).toContain('name')
|
|
})
|
|
|
|
it('should detect boolean properties in nested objects', () => {
|
|
const schema = {
|
|
properties: {
|
|
user: {
|
|
properties: {
|
|
name: true,
|
|
profile: {
|
|
properties: {
|
|
bio: false,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
const errors = forbidBooleanProperties(schema)
|
|
expect(errors).toHaveLength(2)
|
|
expect(errors.some(e => e.includes('user.name'))).toBe(true)
|
|
expect(errors.some(e => e.includes('user.profile.bio'))).toBe(true)
|
|
})
|
|
|
|
it('should handle schema without properties', () => {
|
|
const schema = { type: 'string' }
|
|
const errors = forbidBooleanProperties(schema)
|
|
expect(errors).toHaveLength(0)
|
|
})
|
|
|
|
it('should handle null schema', () => {
|
|
const errors = forbidBooleanProperties(null)
|
|
expect(errors).toHaveLength(0)
|
|
})
|
|
|
|
it('should handle empty schema', () => {
|
|
const errors = forbidBooleanProperties({})
|
|
expect(errors).toHaveLength(0)
|
|
})
|
|
|
|
it('should provide correct path in error messages', () => {
|
|
const schema = {
|
|
properties: {
|
|
level1: {
|
|
properties: {
|
|
level2: {
|
|
properties: {
|
|
level3: true,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
const errors = forbidBooleanProperties(schema)
|
|
expect(errors[0]).toContain('level1.level2.level3')
|
|
})
|
|
})
|
|
})
|