Skip to main content

Example

Read about best practices, or follow the guided example

Angular Testing Library can be used with standalone components and also with Angular components that uses Modules. The example below shows how to test a standalone component, but the same principles apply to Angular components that uses Modules. In fact, there should be no difference in how you test both types of components, only the setup might be different.

counter.component.ts
@Component({
selector: 'app-counter',
template: `
<span>{{ hello() }}</span>
<button (click)="decrement()">-</button>
<span>Current Count: {{ counter() }}</span>
<button (click)="increment()">+</button>
`,
})
export class CounterComponent {
counter = model(0)
hello = input('Hi', {alias: 'greeting'})

increment() {
this.counter.set(this.counter() + 1)
}

decrement() {
this.counter.set(this.counter() - 1)
}
}
counter.component.spec.ts
import {render, screen, fireEvent, aliasedInput} from '@testing-library/angular'
import {CounterComponent} from './counter.component'

describe('Counter', () => {
it('should render counter', async () => {
await render(CounterComponent, {
inputs: {
counter: 5,
// aliases need to be specified using aliasedInput
...aliasedInput('greeting', 'Hello Alias!'),
},
})

expect(screen.getByText('Current Count: 5')).toBeVisible()
expect(screen.getByText('Hello Alias!')).toBeVisible()
})

it('should increment the counter on click', async () => {
await render(CounterComponent, {inputs: {counter: 5}})

const incrementButton = screen.getByRole('button', {name: '+'})
fireEvent.click(incrementButton)

expect(screen.getByText('Current Count: 6')).toBeVisible()
})
})

More examples

More examples can be found in the GitHub project. These examples include:

  • input and output properties
  • Forms
  • Integration injected services
  • And more

If you're looking for an example that isn't on the list, please feel free to create a new issue.