mirror of
https://github.com/Nikolay-Shirokov/cc-1c-skills.git
synced 2026-06-14 18:04:58 +03:00
test(web-test): покрытие quickChoice + radio (RadioButtons)
03-fillfields: - reference-dropdown: переведён с Контрагент на Организация (после смены quickChoice Контрагенты идут через форму выбора) - новый шаг radio: КатегорияЦены через method=radio (RadioButtons) 04-selectvalue: - dropdown: переведён на Организация (quickChoice=true) - новый шаг direct-form: Контрагент (quickChoice=false), method=form Закрывает selectValue#3 dropdown (P0), selectValue#6 direct-form (P1), fillFields#3 radio (P1) из coverage matrix. Tumbler-представление радио (СпособУчёта) пока не покрыто — getFormState не возвращает Tumbler в fields[]. Зафиксировано в upload/web-test-bugs.md пункт 5. 10/10 smoke зелёные на webtest базе. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -4,7 +4,7 @@ export const timeout = 60000;
|
||||
|
||||
const findField = (state, name) => state.fields?.find(f => f.name === name || f.label === name);
|
||||
|
||||
export default async function({ navigateSection, openCommand, clickElement, fillFields, closeForm, getFormState, assert, step, log }) {
|
||||
export default async function({ navigateSection, openCommand, clickElement, fillFields, filterList, closeForm, getFormState, assert, step, log }) {
|
||||
|
||||
await step('text+checkbox+date+dropdown: fillFields на Номенклатура', async () => {
|
||||
await navigateSection('Склад');
|
||||
@@ -33,21 +33,42 @@ export default async function({ navigateSection, openCommand, clickElement, fill
|
||||
await closeForm({ save: false });
|
||||
});
|
||||
|
||||
await step('reference-dropdown: Контрагент → CatalogRef.Контрагенты в новой накладной', async () => {
|
||||
await step('reference-dropdown: Организация → CatalogRef.Организации (quickChoice=true)', async () => {
|
||||
await navigateSection('Склад');
|
||||
await openCommand('Приходная накладная');
|
||||
await clickElement('Создать');
|
||||
|
||||
const fillRes = await fillFields({
|
||||
'Контрагент': 'ООО Север',
|
||||
'Организация': 'Альфа',
|
||||
});
|
||||
log('reference method: ' + fillRes.filled[0]?.method);
|
||||
assert.ok(fillRes.filled[0]?.ok, 'Контрагент fillField должен сработать');
|
||||
assert.ok(fillRes.filled[0]?.ok, 'Организация fillField должна сработать');
|
||||
|
||||
const state = await getFormState();
|
||||
const contractor = findField(state, 'Контрагент');
|
||||
log(`Контрагент value='${contractor?.value}'`);
|
||||
assert.includes(contractor?.value || '', 'Север', 'Контрагент должен показать выбранное значение');
|
||||
const org = findField(state, 'Организация');
|
||||
log(`Организация value='${org?.value}'`);
|
||||
assert.includes(org?.value || '', 'Альфа', 'Организация должна показать выбранное значение');
|
||||
|
||||
await closeForm({ save: false });
|
||||
});
|
||||
|
||||
await step('radio: КатегорияЦены (RadioButtonField, представление RadioButtons)', async () => {
|
||||
// Tumbler-представление (СпособУчёта) пока не покрыто — getFormState не
|
||||
// возвращает Tumbler в fields[]. См. upload/web-test-bugs.md пункт «radio
|
||||
// Tumbler не распознаётся».
|
||||
await navigateSection('Склад');
|
||||
await openCommand('Номенклатура');
|
||||
await filterList('Товар 02');
|
||||
await clickElement('Товар 02', { dblclick: true });
|
||||
|
||||
const result = await fillFields({ 'Категория цены': 'Оптовая' });
|
||||
log('method: ' + result.filled[0]?.method + ', value: ' + result.filled[0]?.value);
|
||||
assert.ok(result.filled[0]?.ok, 'КатегорияЦены fillField должна сработать');
|
||||
assert.equal(result.filled[0]?.method, 'radio', 'КатегорияЦены должна использовать method=radio');
|
||||
|
||||
// Note: getFormState().fields для RadioButtonField возвращает value='' —
|
||||
// выбранный вариант проще проверить через result.filled[].value.
|
||||
assert.includes(result.filled[0]?.value || '', 'Оптовая', 'КатегорияЦены = Оптовая');
|
||||
|
||||
await closeForm({ save: false });
|
||||
});
|
||||
|
||||
@@ -1,20 +1,36 @@
|
||||
export const name = 'selectValue: dropdown быстрый выбор для ссылочного поля';
|
||||
export const name = 'selectValue: dropdown vs форма выбора';
|
||||
export const tags = ['selectvalue', 'smoke'];
|
||||
export const timeout = 60000;
|
||||
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, getFormState, assert, step, log }) {
|
||||
export default async function({ navigateSection, openCommand, clickElement, selectValue, closeForm, assert, step, log }) {
|
||||
|
||||
await step('dropdown: Контрагент → CatalogRef.Контрагенты, малый список', async () => {
|
||||
await step('dropdown: Организация → CatalogRef.Организации (quickChoice=true)', async () => {
|
||||
await navigateSection('Склад');
|
||||
await openCommand('Приходная накладная');
|
||||
await clickElement('Создать');
|
||||
|
||||
const result = await selectValue('Контрагент', 'ООО Север');
|
||||
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 || '', 'Север', 'Контрагент должен показать выбранное значение');
|
||||
|
||||
Reference in New Issue
Block a user