Skip to content

Commit

Permalink
Test(web-react): Refactor ButtonLink test using screen and roles
Browse files Browse the repository at this point in the history
  • Loading branch information
literat committed Nov 26, 2024
1 parent da1cc61 commit a9e8472
Showing 1 changed file with 17 additions and 17 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import '@testing-library/jest-dom';
import { render } from '@testing-library/react';
import { render, screen } from '@testing-library/react';
import React from 'react';
import { classNamePrefixProviderTest } from '../../../../tests/providerTests/classNamePrefixProviderTest';
import {
Expand Down Expand Up @@ -28,61 +28,61 @@ describe('ButtonLink', () => {
restPropsTest(ButtonLink, 'a');

it('should have default classname', () => {
const { container } = render(<ButtonLink />);
render(<ButtonLink />);

const element = container.querySelector('a') as HTMLElement;
const element = screen.getByRole('button');
expect(element).toHaveClass('Button--primary');
});

it('should have disabled classname', () => {
const { container } = render(<ButtonLink isDisabled />);
render(<ButtonLink isDisabled />);

const element = container.querySelector('a') as HTMLElement;
const element = screen.getByRole('button');
expect(element).toHaveClass('Button');
expect(element).toHaveClass('Button--disabled');
});

it('should have block classname', () => {
const { container } = render(<ButtonLink isBlock />);
render(<ButtonLink isBlock />);

const element = container.querySelector('a') as HTMLElement;
const element = screen.getByRole('button');
expect(element).toHaveClass('Button');
expect(element).toHaveClass('Button--block');
});

it('should have size classname', () => {
const { container } = render(<ButtonLink size="medium" />);
render(<ButtonLink size="medium" />);

const element = container.querySelector('a') as HTMLElement;
const element = screen.getByRole('button');
expect(element).toHaveClass('Button');
expect(element).toHaveClass('Button--medium');
});

it('should render text children', () => {
const dom = render(<ButtonLink>Hello World</ButtonLink>);
render(<ButtonLink>Hello World</ButtonLink>);

const element = dom.container.querySelector('a') as HTMLElement;
const element = screen.getByRole('button');
expect(element.textContent).toBe('Hello World');
});

it('should not have default type attribute', () => {
const { container } = render(<ButtonLink />);
render(<ButtonLink />);

const element = container.querySelector('a') as HTMLElement;
const element = screen.getByRole('button');
expect(element).not.toHaveAttribute('type');
});

it('should pass rel attribute', () => {
const { container } = render(<ButtonLink rel="noopener" />);
render(<ButtonLink rel="noopener" />);

const element = container.querySelector('a') as HTMLElement;
const element = screen.getByRole('button');
expect(element).toHaveAttribute('rel', 'noopener');
});

it('should pass target attribute', () => {
const { container } = render(<ButtonLink target="_blank" />);
render(<ButtonLink target="_blank" />);

const element = container.querySelector('a') as HTMLElement;
const element = screen.getByRole('button');
expect(element).toHaveAttribute('target', '_blank');
});
});

0 comments on commit a9e8472

Please sign in to comment.