mirror of
https://github.com/Nikolay-Shirokov/cc-1c-skills.git
synced 2026-06-11 00:14:56 +03:00
486890c388
Step auto-history полагался на наполненную UserChoiceHistory от предыдущих тестов
(06-document и т.д.) — в одиночном прогоне history для 'ООО Юг' пустая,
typeahead не активировался, method=form вместо ожидаемого dropdown.
History в 1С — per-value: первый выбор значения через form наполняет историю,
второй выбор того же значения идёт через typeahead-dropdown. Добавлен warm-up:
selectValue('Менеджер', 'ООО Юг') → clear → второй selectValue того же значения
(уже из истории).
Закрывает §0.8 #4 родительского плана. Регресс одиночный + полный 19/19 зелёный.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
91 lines
5.3 KiB
JavaScript
91 lines
5.3 KiB
JavaScript
export const name = 'selectValue: dropdown vs форма выбора';
|
||
export const tags = ['selectvalue', 'smoke'];
|
||
export const timeout = 90000;
|
||
|
||
const findField = (state, name) => state.fields?.find(f => f.name === name || f.label === name);
|
||
|
||
export default async function({ navigateSection, openCommand, clickElement, selectValue, closeForm, assert, step, log }) {
|
||
|
||
await step('dropdown: Организация → CatalogRef.Организации (quickChoice=true)', async () => {
|
||
await navigateSection('Склад');
|
||
await openCommand('Приходная накладная');
|
||
await clickElement('Создать');
|
||
|
||
const result = await selectValue('Организация', 'Альфа');
|
||
log(`method=${result.selected?.method}, search=${result.selected?.search}`);
|
||
assert.equal(result.selected?.method, 'dropdown', 'Должен быть метод dropdown (быстрый выбор)');
|
||
|
||
const field = findField(result, 'Организация');
|
||
log(`Организация value='${field?.value}'`);
|
||
assert.includes(field?.value || '', 'Альфа', 'Организация должна показать выбранное значение');
|
||
|
||
await closeForm({ save: false });
|
||
});
|
||
|
||
await step('direct-form: Контрагент → CatalogRef.Контрагенты (quickChoice=false)', async () => {
|
||
await navigateSection('Склад');
|
||
await openCommand('Приходная накладная');
|
||
await clickElement('Создать');
|
||
|
||
const result = await selectValue('Контрагент', 'Север');
|
||
log(`method=${result.selected?.method}, search=${result.selected?.search}`);
|
||
assert.equal(result.selected?.method, 'form', 'Должен быть метод form (через форму выбора)');
|
||
|
||
const field = findField(result, 'Контрагент');
|
||
log(`Контрагент value='${field?.value}'`);
|
||
assert.includes(field?.value || '', 'Север', 'Контрагент должен показать выбранное значение');
|
||
|
||
await closeForm({ save: false });
|
||
});
|
||
|
||
await step('auto-history: choiceHistoryOnInput=Auto → method=dropdown даже на ссылке без quickChoice', async () => {
|
||
// Менеджер и Контрагент оба ссылаются на CatalogRef.Контрагенты (quickChoice=false).
|
||
// Отличие — choiceHistoryOnInput:
|
||
// Контрагент: 'DontUse' → typeahead-dropdown подавлен → selectValue идёт в form
|
||
// Менеджер: 'Auto' (дефолт) → typeahead активен → selectValue остаётся в dropdown
|
||
// Шаг подтверждает, что флаг управляет path внутри selectValue.
|
||
//
|
||
// history наполняется per-value при выборе. Делаем warm-up через form, чтобы
|
||
// second pick шёл из истории — иначе isolation-прогон зависит от того,
|
||
// выбирали ли 'ООО Юг' в предыдущих тестах (06-document и т.д.).
|
||
await navigateSection('Склад');
|
||
await openCommand('Приходная накладная');
|
||
await clickElement('Создать');
|
||
|
||
// Warm-up: первый выбор может пойти через form (если history пустая).
|
||
// Не делаем assertions — только наполняем историю.
|
||
await selectValue('Менеджер', 'ООО Юг');
|
||
await selectValue('Менеджер', ''); // clear, оставляем форму открытой
|
||
|
||
// Второй выбор того же значения — должен взяться из history через typeahead.
|
||
const r = await selectValue('Менеджер', 'ООО Юг');
|
||
log(`Менеджер (Auto): method=${r.selected?.method}`);
|
||
assert.equal(r.selected?.method, 'dropdown',
|
||
'Auto-история включена → typeahead-dropdown → method=dropdown (vs form у Контрагент)');
|
||
|
||
const field = findField(r, 'Менеджер');
|
||
assert.includes(field?.value || '', 'Юг', 'значение установилось из dropdown');
|
||
|
||
await closeForm({ save: false });
|
||
});
|
||
|
||
await step('clear: selectValue с пустым search → Shift+F4', async () => {
|
||
await navigateSection('Склад');
|
||
await openCommand('Приходная накладная');
|
||
await clickElement('Создать');
|
||
|
||
await selectValue('Организация', 'Альфа');
|
||
const before = await selectValue('Организация', ''); // empty → clear
|
||
const field = findField(before, 'Организация');
|
||
log(`Организация after clear value='${field?.value}'`);
|
||
assert.equal(field?.value, '', 'Организация должна быть очищена');
|
||
|
||
await closeForm({ save: false });
|
||
});
|
||
|
||
}
|
||
// show-all-form ветка (P1 в матрице) требует quickChoice=true каталога с
|
||
// количеством > порога dropdown, чтобы появилась ссылка "Показать все".
|
||
// В текущей синтетике такого каталога нет (Организации ~2 элемента, остальные
|
||
// quickChoice=false). Откладывается до расширения синтетики.
|