169 похожих чатов

Привет, подскажите пожалуйста Начал писать юнит тесты для презентационных компонентов @Component({

selector: '...',
standalone: true,
imports: [...],
template: `
<cd-flat-button
(clicked)="createClicked.emit()"
icon="plus"
text="Create"
/>

<cd-stroked-button
class="button"
(clicked)="columnsClicked.emit()"
icon="view-columns"
text="Columns"
/>

<cd-stroked-button
class="button"
(clicked)="exportClicked.emit()"
icon="export"
text="Export"
/>

<cd-flat-button
*ngIf="showDelete"
class="button"
(clicked)="deleteClicked.emit()"
icon="trash"
/>
`,
styles: [
`
.button {
margin-inline-start: 8px;
}
`,
],
changeDetection: ChangeDetectionStrategy.OnPush,
})
export class ActionButtonsComponent {
@Input() showDelete = false;

@Output() readonly createClicked = new EventEmitter<void>();
@Output() readonly columnsClicked = new EventEmitter<void>();
@Output() readonly exportClicked = new EventEmitter<void>();
@Output() readonly deleteClicked = new EventEmitter<void>();
}

И вот как будет правильнее
Сделать методы в классе onCreateClicked() / onColumnsClicked() / ... и вызывать эти методы в темплейте, тем самым я буду покрывать тестами эти методы

Или через document.querySelector получать кнопки и кликать на них, и тем самым смотреть работу output'ов

Как вы решаете данную проблему? Так как получать кнопки через селектор означает, что еще классы нужно вешать, но с другой стороны без доп методов, которые как по мне не нужны

4 ответов

14 просмотров

честно говоря эти output-ы выглядят крайне странно, как и сам компонент, я бы в темплейт засунул только ng-content а кнопки прокидывал сверху

запускать spyon на эмиттер. кликать на пункт. проверять, что .emit вызван

qbeeck- Автор вопроса
Evgheni Чернявский
честно говоря эти output-ы выглядят крайне странно...

идея заключалась в том, что есть 5 мест, где нужно показывать эти 4 кнопки и в моем случае есть 1 компонент, который показывает эти 4 кнопки одним тегом без доп импортов в такой бы ты ситуации, все также бы поступил?

qbeeck
идея заключалась в том, что есть 5 мест, где нужно...

да, сильно много кода это не прибавит, но избавит от проблем если появится место с 3 кнопками

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Карта сайта