Skip to content

Commit

Permalink
Add comment suggestions
Browse files Browse the repository at this point in the history
  • Loading branch information
EMaksy committed Mar 14, 2023
1 parent f602cea commit 0efbed7
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 30 deletions.
29 changes: 12 additions & 17 deletions assets/js/components/ExecutionResults/ExecutionResults.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -28,28 +28,20 @@ const addHostnameToTargets = (targets, hostnames) =>
};
});

function MarkdownContent({ children }) {
return (
<ReactMarkdown className="markdown" remarkPlugins={[remarkGfm]}>
{children}
</ReactMarkdown>
);
}

const resultsTableConfig = {
usePadding: false,
columns: [
{
title: 'Id',
key: 'checkID',
render: (checkID, item) => (
render: (checkID, { onClick }) => (
<div className="whitespace-nowrap text-jungle-green-500">
<span
className="inline-block"
aria-hidden="true"
onClick={(e) => {
e.stopPropagation();
item.onClickRemediation();
onClick();
}}
>
{checkID}
Expand All @@ -60,7 +52,11 @@ const resultsTableConfig = {
{
title: 'Description',
key: 'description',
render: (description) => <MarkdownContent>{description}</MarkdownContent>,
render: (description) => (
<ReactMarkdown className="markdown" remarkPlugins={[remarkGfm]}>
{description}
</ReactMarkdown>
),
},
{
title: 'Result',
Expand Down Expand Up @@ -153,7 +149,7 @@ function ExecutionResults({
description: getCheckDescription(catalog, checkID),
expectationResults,
agentsCheckResults: addHostnameToTargets(agentsCheckResults, hostnames),
onClickRemediation: () => {
onClick: () => {
setModalOpen(true);
setSelectedCheck(checkID);
},
Expand Down Expand Up @@ -181,22 +177,21 @@ function ExecutionResults({
hosts={hosts}
onContentRefresh={onContentRefresh}
onStartExecution={onStartExecution}
selectedCheck={selectedCheck}
>
<Table config={resultsTableConfig} data={tableData} />
</ResultsContainer>
<Modal
open={modalOpen}
title={
<MarkdownContent>
<ReactMarkdown className="markdown" remarkPlugins={[remarkGfm]}>
{getCheckDescription(catalog, selectedCheck)}
</MarkdownContent>
</ReactMarkdown>
}
onClose={() => setModalOpen(false)}
>
<MarkdownContent>
<ReactMarkdown className="markdown" remarkPlugins={[remarkGfm]}>
{getCheckRemediation(catalog, selectedCheck)}
</MarkdownContent>
</ReactMarkdown>
</Modal>
</>
);
Expand Down
24 changes: 11 additions & 13 deletions assets/js/components/ExecutionResults/ExecutionResults.test.jsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import React from 'react';
import { screen, fireEvent } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import { faker } from '@faker-js/faker';
import { renderWithRouter } from '@lib/test-utils';

Expand Down Expand Up @@ -411,7 +412,7 @@ describe('ExecutionResults', () => {
).toBeTruthy();
});

it('should open remediation modal when clicking on checkID', async () => {
it('should open remediation modal when clicking on checkID and close it when clicking outside', async () => {
const {
clusterID,
hostnames,
Expand All @@ -438,13 +439,12 @@ describe('ExecutionResults', () => {
);

const { id: checkID, remediation } = catalog[0];
const clickableID = screen.getByText(checkID);
expect(clickableID.textContent).toBe(checks[0]);
let remediationModalElement = screen.queryByText(remediation);
expect(remediationModalElement).not.toBeInTheDocument();
fireEvent.click(clickableID);
remediationModalElement = screen.getByText(remediation);
expect(remediationModalElement).toBeInTheDocument();
expect(screen.getByText(checkID).textContent).toBe(checks[0]);
expect(screen.queryByText(remediation)).not.toBeInTheDocument();
fireEvent.click(screen.getByText(checkID));
expect(screen.queryByText(remediation)).toBeInTheDocument();
await userEvent.click(document.body);
expect(screen.queryByText(remediation)).not.toBeInTheDocument();
});

it('should not open remediation modal when clicking on description', async () => {
Expand Down Expand Up @@ -474,10 +474,8 @@ describe('ExecutionResults', () => {
);

const { remediation, description } = catalog[0];
const checkDescriptionText = screen.getByText(description);
expect(description).toBe(checkDescriptionText.textContent);
fireEvent.click(checkDescriptionText);
const remediationModalElement = screen.queryByText(remediation);
expect(remediationModalElement).not.toBeInTheDocument();
expect(screen.getByText(description).textContent).toBe(description);
userEvent.click(screen.getByText(description));
expect(screen.queryByText(remediation)).not.toBeInTheDocument();
});
});

0 comments on commit 0efbed7

Please sign in to comment.