test: PR#28测试覆盖 — 用户名大小写、一次改名、自动翻译、去重
All checks were successful
PR Preview / test (pull_request) Has been skipped
Deploy Production / test (push) Successful in 6s
PR Preview / teardown-preview (pull_request) Successful in 13s
Test / unit-test (push) Successful in 5s
PR Preview / deploy-preview (pull_request) Has been skipped
Test / build-check (push) Successful in 4s
Deploy Production / deploy (push) Successful in 6s
Test / e2e-test (push) Successful in 49s
All checks were successful
PR Preview / test (pull_request) Has been skipped
Deploy Production / test (push) Successful in 6s
PR Preview / teardown-preview (pull_request) Successful in 13s
Test / unit-test (push) Successful in 5s
PR Preview / deploy-preview (pull_request) Has been skipped
Test / build-check (push) Successful in 4s
Deploy Production / deploy (push) Successful in 6s
Test / e2e-test (push) Successful in 49s
单元测试274个(新增18个): - recipeNameEn额外用例、oilEn翻译、用户名大小写匹配、改名守卫 E2E新增: - 注册大小写去重、登录大小写匹配、一次改名+拒绝二次 - 配方自动翻译、改名重翻译、删除用户转移配方 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit was merged in pull request #28.
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
import { describe, it, expect } from 'vitest'
|
||||
import { recipeNameEn } from '../composables/useOilTranslation'
|
||||
import { recipeNameEn, oilEn } from '../composables/useOilTranslation'
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
// EDITOR_ONLY_TAGS includes '已下架'
|
||||
@@ -169,4 +169,117 @@ describe('duplicate oil prevention', () => {
|
||||
const isDup = ings.some(i => i !== ing && i.oil === '薰衣草')
|
||||
expect(isDup).toBe(false)
|
||||
})
|
||||
|
||||
it('handles empty ingredient list (no duplicates)', () => {
|
||||
const ings = []
|
||||
const isDup = ings.some(i => i.oil === '薰衣草')
|
||||
expect(isDup).toBe(false)
|
||||
})
|
||||
})
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
// recipeNameEn — additional edge cases for PR28
|
||||
// ---------------------------------------------------------------------------
|
||||
describe('recipeNameEn — PR28 additional cases', () => {
|
||||
it('translates 排毒配方 → Detox Blend', () => {
|
||||
expect(recipeNameEn('排毒配方')).toBe('Detox Blend')
|
||||
})
|
||||
|
||||
it('translates 呼吸系统护理 → Respiratory System Care', () => {
|
||||
expect(recipeNameEn('呼吸系统护理')).toBe('Respiratory System Care')
|
||||
})
|
||||
|
||||
it('translates 儿童助眠 → Children\'s Sleep Aid', () => {
|
||||
expect(recipeNameEn('儿童助眠')).toBe("Children's Sleep Aid")
|
||||
})
|
||||
|
||||
it('translates 美容按摩 → Beauty Massage', () => {
|
||||
expect(recipeNameEn('美容按摩')).toBe('Beauty Massage')
|
||||
})
|
||||
|
||||
it('handles mixed Chinese and ASCII text', () => {
|
||||
// Unknown Chinese chars are skipped; if ASCII appears, it's kept
|
||||
const result = recipeNameEn('testBlend')
|
||||
// No Chinese keyword matches, falls back to original
|
||||
expect(result).toBe('testBlend')
|
||||
})
|
||||
|
||||
it('handles single-keyword name', () => {
|
||||
expect(recipeNameEn('免疫')).toBe('Immunity')
|
||||
})
|
||||
|
||||
it('translates compound: 肩颈按摩配方 → Neck & Shoulder Massage Blend', () => {
|
||||
expect(recipeNameEn('肩颈按摩配方')).toBe('Neck & Shoulder Massage Blend')
|
||||
})
|
||||
})
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
// oilEn — English oil name translation
|
||||
// ---------------------------------------------------------------------------
|
||||
describe('oilEn', () => {
|
||||
it('translates known oils', () => {
|
||||
expect(oilEn('薰衣草')).toBe('Lavender')
|
||||
expect(oilEn('茶树')).toBe('Tea Tree')
|
||||
expect(oilEn('乳香')).toBe('Frankincense')
|
||||
})
|
||||
|
||||
it('handles 复方 suffix removal', () => {
|
||||
expect(oilEn('舒缓复方')).toBe('Past Tense')
|
||||
})
|
||||
|
||||
it('handles 复方 suffix addition', () => {
|
||||
// '呼吸' maps via '呼吸复方' → 'Breathe'
|
||||
expect(oilEn('呼吸')).toBe('Breathe')
|
||||
})
|
||||
|
||||
it('returns empty string for unknown oil', () => {
|
||||
expect(oilEn('不存在的油')).toBe('')
|
||||
})
|
||||
})
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
// Case-insensitive username logic (pure function)
|
||||
// ---------------------------------------------------------------------------
|
||||
describe('case-insensitive username matching', () => {
|
||||
const matchCaseInsensitive = (input, existing) =>
|
||||
existing.some(u => u.toLowerCase() === input.toLowerCase())
|
||||
|
||||
it('detects duplicate usernames case-insensitively', () => {
|
||||
const existing = ['TestUser', 'Alice', 'Bob']
|
||||
expect(matchCaseInsensitive('testuser', existing)).toBe(true)
|
||||
expect(matchCaseInsensitive('TESTUSER', existing)).toBe(true)
|
||||
expect(matchCaseInsensitive('TestUser', existing)).toBe(true)
|
||||
})
|
||||
|
||||
it('allows unique username', () => {
|
||||
const existing = ['TestUser', 'Alice']
|
||||
expect(matchCaseInsensitive('Charlie', existing)).toBe(false)
|
||||
})
|
||||
|
||||
it('is case-insensitive for mixed-case inputs', () => {
|
||||
const existing = ['alice']
|
||||
expect(matchCaseInsensitive('Alice', existing)).toBe(true)
|
||||
expect(matchCaseInsensitive('ALICE', existing)).toBe(true)
|
||||
expect(matchCaseInsensitive('aLiCe', existing)).toBe(true)
|
||||
})
|
||||
})
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
// One-time username change logic
|
||||
// ---------------------------------------------------------------------------
|
||||
describe('one-time username change guard', () => {
|
||||
it('blocks rename when username_changed is truthy', () => {
|
||||
const user = { username_changed: 1 }
|
||||
expect(!!user.username_changed).toBe(true)
|
||||
})
|
||||
|
||||
it('allows rename when username_changed is falsy', () => {
|
||||
const user = { username_changed: 0 }
|
||||
expect(!!user.username_changed).toBe(false)
|
||||
})
|
||||
|
||||
it('allows rename when username_changed is undefined', () => {
|
||||
const user = {}
|
||||
expect(!!user.username_changed).toBe(false)
|
||||
})
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user