import { expect } from 'chai' import { render, screen } from '@testing-library/react' import ToolbarHeader from '../../../../../frontend/js/features/editor-navigation-toolbar/components/toolbar-header' describe('', function () { const defaultProps = { onShowLeftMenuClick: () => {}, toggleChatOpen: () => {}, toggleReviewPanelOpen: () => {}, toggleHistoryOpen: () => {}, unreadMessageCount: 0, onlineUsers: [], goToUser: () => {}, projectName: 'test project', renameProject: () => {}, openShareModal: () => {}, togglePdfView: () => {}, hasPublishPermissions: true, } describe('cobranding logo', function () { it('is not displayed by default', function () { render() expect(screen.queryByRole('link', { name: 'variation' })).to.not.exist }) it('is displayed when cobranding data is available', function () { const props = { ...defaultProps, cobranding: { brandVariationHomeUrl: 'http://cobranding', brandVariationName: 'variation', logoImgUrl: 'http://cobranding/logo', }, } render() screen.getByRole('link', { name: 'variation' }) }) }) describe('pdf toggle button', function () { it('is not displayed by default', function () { render() expect(screen.queryByText('PDF')).to.not.exist }) it('is displayed when "pdfButtonIsVisible" prop is set to true', function () { const props = { ...defaultProps, pdfButtonIsVisible: true, } render() screen.getByText('PDF') }) }) describe('track changes toggle button', function () { it('is displayed by default', function () { render() screen.getByText('Review') }) it('is not displayed when "isRestrictedTokenMember" prop is set to true', function () { const props = { ...defaultProps, isRestrictedTokenMember: true, } render() expect(screen.queryByText('Review')).to.not.exist }) }) describe('History toggle button', function () { it('is displayed by default', function () { render() screen.getByText('History') }) it('is not displayed when "isRestrictedTokenMember" prop is set to true', function () { const props = { ...defaultProps, isRestrictedTokenMember: true, } render() expect(screen.queryByText('History')).to.not.exist }) }) describe('Chat toggle button', function () { it('is displayed by default', function () { render() screen.getByText('Chat') }) it('is not displayed when "isRestrictedTokenMember" prop is set to true', function () { const props = { ...defaultProps, isRestrictedTokenMember: true, } render() expect(screen.queryByText('Chat')).to.not.exist }) }) describe('Publish button', function () { it('is displayed by default', function () { render() screen.getByText('Submit') }) it('is not displayed for users with no publish permissions', function () { const props = { ...defaultProps, hasPublishPermissions: false, } render() expect(screen.queryByText('Submit')).to.not.exist }) }) })