mirror of
https://github.com/langgenius/dify.git
synced 2026-03-12 18:48:53 +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>
231 lines
9.6 KiB
TypeScript
231 lines
9.6 KiB
TypeScript
import { mergeValidCompletionParams } from './completion-params'
|
|
import type { FormValue, ModelParameterRule } from '@/app/components/header/account-setting/model-provider-page/declarations'
|
|
|
|
describe('completion-params', () => {
|
|
describe('mergeValidCompletionParams', () => {
|
|
test('returns empty params and removedDetails for undefined oldParams', () => {
|
|
const rules: ModelParameterRule[] = []
|
|
const result = mergeValidCompletionParams(undefined, rules)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('returns empty params and removedDetails for empty oldParams', () => {
|
|
const rules: ModelParameterRule[] = []
|
|
const result = mergeValidCompletionParams({}, rules)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('validates int type parameter within range', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'max_tokens', type: 'int', min: 1, max: 4096, label: { en_US: 'Max Tokens', zh_Hans: '最大标记' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { max_tokens: 100 }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({ max_tokens: 100 })
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('removes int parameter below minimum', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'max_tokens', type: 'int', min: 1, max: 4096, label: { en_US: 'Max Tokens', zh_Hans: '最大标记' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { max_tokens: 0 }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails).toEqual({ max_tokens: 'out of range (1-4096)' })
|
|
})
|
|
|
|
test('removes int parameter above maximum', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'max_tokens', type: 'int', min: 1, max: 4096, label: { en_US: 'Max Tokens', zh_Hans: '最大标记' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { max_tokens: 5000 }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails).toEqual({ max_tokens: 'out of range (1-4096)' })
|
|
})
|
|
|
|
test('removes int parameter with invalid type', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'max_tokens', type: 'int', min: 1, max: 4096, label: { en_US: 'Max Tokens', zh_Hans: '最大标记' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { max_tokens: 'not a number' as any }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails).toEqual({ max_tokens: 'invalid type' })
|
|
})
|
|
|
|
test('validates float type parameter', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'temperature', type: 'float', min: 0, max: 2, label: { en_US: 'Temperature', zh_Hans: '温度' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { temperature: 0.7 }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({ temperature: 0.7 })
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('validates float at boundary values', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'temperature', type: 'float', min: 0, max: 2, label: { en_US: 'Temperature', zh_Hans: '温度' }, required: false },
|
|
]
|
|
|
|
const result1 = mergeValidCompletionParams({ temperature: 0 }, rules)
|
|
expect(result1.params).toEqual({ temperature: 0 })
|
|
|
|
const result2 = mergeValidCompletionParams({ temperature: 2 }, rules)
|
|
expect(result2.params).toEqual({ temperature: 2 })
|
|
})
|
|
|
|
test('validates boolean type parameter', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'stream', type: 'boolean', label: { en_US: 'Stream', zh_Hans: '流' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { stream: true }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({ stream: true })
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('removes boolean parameter with invalid type', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'stream', type: 'boolean', label: { en_US: 'Stream', zh_Hans: '流' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { stream: 'yes' as any }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails).toEqual({ stream: 'invalid type' })
|
|
})
|
|
|
|
test('validates string type parameter', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'model', type: 'string', label: { en_US: 'Model', zh_Hans: '模型' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { model: 'gpt-4' }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({ model: 'gpt-4' })
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('validates string parameter with options', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'model', type: 'string', options: ['gpt-3.5-turbo', 'gpt-4'], label: { en_US: 'Model', zh_Hans: '模型' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { model: 'gpt-4' }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({ model: 'gpt-4' })
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('removes string parameter with invalid option', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'model', type: 'string', options: ['gpt-3.5-turbo', 'gpt-4'], label: { en_US: 'Model', zh_Hans: '模型' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { model: 'invalid-model' }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails).toEqual({ model: 'unsupported option' })
|
|
})
|
|
|
|
test('validates text type parameter', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'prompt', type: 'text', label: { en_US: 'Prompt', zh_Hans: '提示' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { prompt: 'Hello world' }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({ prompt: 'Hello world' })
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('removes unsupported parameters', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'temperature', type: 'float', min: 0, max: 2, label: { en_US: 'Temperature', zh_Hans: '温度' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { temperature: 0.7, unsupported_param: 'value' }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({ temperature: 0.7 })
|
|
expect(result.removedDetails).toEqual({ unsupported_param: 'unsupported' })
|
|
})
|
|
|
|
test('keeps stop parameter in advanced mode even without rule', () => {
|
|
const rules: ModelParameterRule[] = []
|
|
const oldParams: FormValue = { stop: ['END'] }
|
|
const result = mergeValidCompletionParams(oldParams, rules, true)
|
|
|
|
expect(result.params).toEqual({ stop: ['END'] })
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('removes stop parameter in normal mode without rule', () => {
|
|
const rules: ModelParameterRule[] = []
|
|
const oldParams: FormValue = { stop: ['END'] }
|
|
const result = mergeValidCompletionParams(oldParams, rules, false)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails).toEqual({ stop: 'unsupported' })
|
|
})
|
|
|
|
test('handles multiple parameters with mixed validity', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'temperature', type: 'float', min: 0, max: 2, label: { en_US: 'Temperature', zh_Hans: '温度' }, required: false },
|
|
{ name: 'max_tokens', type: 'int', min: 1, max: 4096, label: { en_US: 'Max Tokens', zh_Hans: '最大标记' }, required: false },
|
|
{ name: 'model', type: 'string', options: ['gpt-4'], label: { en_US: 'Model', zh_Hans: '模型' }, required: false },
|
|
]
|
|
const oldParams: FormValue = {
|
|
temperature: 0.7,
|
|
max_tokens: 5000,
|
|
model: 'gpt-4',
|
|
unsupported: 'value',
|
|
}
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({
|
|
temperature: 0.7,
|
|
model: 'gpt-4',
|
|
})
|
|
expect(result.removedDetails).toEqual({
|
|
max_tokens: 'out of range (1-4096)',
|
|
unsupported: 'unsupported',
|
|
})
|
|
})
|
|
|
|
test('handles parameters without min/max constraints', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'value', type: 'int', label: { en_US: 'Value', zh_Hans: '值' }, required: false },
|
|
]
|
|
const oldParams: FormValue = { value: 999999 }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({ value: 999999 })
|
|
expect(result.removedDetails).toEqual({})
|
|
})
|
|
|
|
test('removes parameter with unsupported rule type', () => {
|
|
const rules: ModelParameterRule[] = [
|
|
{ name: 'custom', type: 'unknown_type', label: { en_US: 'Custom', zh_Hans: '自定义' }, required: false } as any,
|
|
]
|
|
const oldParams: FormValue = { custom: 'value' }
|
|
const result = mergeValidCompletionParams(oldParams, rules)
|
|
|
|
expect(result.params).toEqual({})
|
|
expect(result.removedDetails.custom).toContain('unsupported rule type')
|
|
})
|
|
})
|
|
})
|