mirror of
https://github.com/Nikolay-Shirokov/cc-1c-skills.git
synced 2026-06-11 00:14:56 +03:00
71e3691cf1
02-crud: confirm-save-no (rollback при save:false), confirm-pending (closeForm() без решения возвращает confirmation), more-menu (clickElement 'Ещё' возвращает submenu). 03-fillfields: clear (Shift+F4 через пустое значение), reference-non-quickchoice (fillFields на quickChoice=false поле — method=dropdown через DLB; чистый form-path требует hasPick && !hasSelect, такого поля в синтетике нет). 04-selectvalue: clear (selectValue '' → Shift+F4). show-all-form отложен — требует quickChoice=true каталога с количеством > порога dropdown (в синтетике нет). 05-table: checkbox (fillTableRow с Boolean), clear (Shift+F4 на ref-ячейке + восстановление для последующего delete). Live на webtest: все шаги проходят. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
89 lines
4.6 KiB
JavaScript
89 lines
4.6 KiB
JavaScript
export const name = 'Табличная часть: add, edit, delete на Товары накладной';
|
|
export const tags = ['table', 'smoke'];
|
|
export const timeout = 90000;
|
|
|
|
export default async function({ navigateSection, openCommand, clickElement, fillFields, fillTableRow, deleteTableRow, readTable, closeForm, getFormState, assert, step, log }) {
|
|
|
|
await step('add: добавить две строки в Товары через fillTableRow add:true', async () => {
|
|
await navigateSection('Склад');
|
|
await openCommand('Приходная накладная');
|
|
await clickElement('Создать');
|
|
await fillFields({ 'Контрагент': 'ООО Север' });
|
|
|
|
await fillTableRow(
|
|
{ 'Номенклатура': 'Товар 01', 'Количество': '5', 'Цена': '100' },
|
|
{ table: 'Товары', add: true }
|
|
);
|
|
await fillTableRow(
|
|
{ 'Номенклатура': 'Товар 02', 'Количество': '3', 'Цена': '200' },
|
|
{ table: 'Товары', add: true }
|
|
);
|
|
|
|
const t = await readTable({ table: 'Товары' });
|
|
log(`rows after add: ${t.rows?.length}`);
|
|
assert.equal(t.rows?.length, 2, 'Должно быть 2 строки');
|
|
assert.equal(t.rows[0]['Номенклатура'], 'Товар 01', 'Строка 0 = Товар 01');
|
|
assert.equal(t.rows[1]['Номенклатура'], 'Товар 02', 'Строка 1 = Товар 02');
|
|
});
|
|
|
|
await step('edit: изменить количество в строке 0 через fillTableRow row:0', async () => {
|
|
await fillTableRow(
|
|
{ 'Количество': '10' },
|
|
{ table: 'Товары', row: 0 }
|
|
);
|
|
const t = await readTable({ table: 'Товары' });
|
|
log(`row 0 after edit: ${JSON.stringify(t.rows[0])}`);
|
|
assert.equal(t.rows[0]['Количество'], '10,000', 'Количество строки 0 = 10');
|
|
});
|
|
|
|
await step('tab-loop: изменить два числовых поля в строке 1 одним вызовом', async () => {
|
|
const r = await fillTableRow(
|
|
{ 'Количество': '7', 'Цена': '150' },
|
|
{ table: 'Товары', row: 1 }
|
|
);
|
|
log(`tab-loop result: ${JSON.stringify(r)}`);
|
|
const t = await readTable({ table: 'Товары' });
|
|
log(`row 1 after tab-loop: ${JSON.stringify(t.rows[1])}`);
|
|
assert.equal(t.rows[1]['Количество'], '7,000', 'Количество строки 1 = 7');
|
|
assert.equal(t.rows[1]['Цена'], '150,00', 'Цена строки 1 = 150');
|
|
});
|
|
|
|
await step('checkbox: переключить Согласовано в строке 1 через fillTableRow', async () => {
|
|
const r = await fillTableRow(
|
|
{ 'Согласовано': true },
|
|
{ table: 'Товары', row: 1 }
|
|
);
|
|
log(`checkbox result: ${JSON.stringify(r.filled || r)}`);
|
|
const t = await readTable({ table: 'Товары' });
|
|
log(`row 1 Согласовано='${t.rows[1]['Согласовано']}'`);
|
|
assert.equal(t.rows[1]['Согласовано'], 'true', 'Согласовано должно стать true');
|
|
});
|
|
|
|
await step('clear: очистить ссылочную ячейку Номенклатура через fillTableRow с пустым значением', async () => {
|
|
// Используем строку 0 (Товар 01)
|
|
const r = await fillTableRow(
|
|
{ 'Номенклатура': '' },
|
|
{ table: 'Товары', row: 0 }
|
|
);
|
|
log(`clear result: ${JSON.stringify(r.filled || r)}`);
|
|
const t = await readTable({ table: 'Товары' });
|
|
log(`row 0 Номенклатура after clear='${t.rows[0]['Номенклатура']}'`);
|
|
assert.equal(t.rows[0]['Номенклатура'], '', 'Номенклатура должна быть очищена (Shift+F4)');
|
|
|
|
// Восстанавливаем Товар 01 чтобы последующий delete мог работать с предсказуемым состоянием
|
|
await fillTableRow(
|
|
{ 'Номенклатура': 'Товар 01' },
|
|
{ table: 'Товары', row: 0 }
|
|
);
|
|
});
|
|
|
|
await step('delete: удалить первую строку', async () => {
|
|
await deleteTableRow(0, { table: 'Товары' });
|
|
const t = await readTable({ table: 'Товары' });
|
|
log(`rows after delete: ${t.rows?.length}, [0]=${t.rows[0]?.['Номенклатура']}`);
|
|
assert.equal(t.rows?.length, 1, 'Должна остаться 1 строка');
|
|
assert.equal(t.rows[0]['Номенклатура'], 'Товар 02', 'Осталась строка Товар 02');
|
|
await closeForm({ save: false });
|
|
});
|
|
}
|