Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(test) O3-3937 Add test coverage around form readonly mode #401

Merged
merged 2 commits into from
Oct 23, 2024
Merged

Conversation

CynthiaKamau
Copy link
Contributor

@CynthiaKamau CynthiaKamau commented Sep 25, 2024

Requirements

  • This PR has a title that briefly describes the work done including the ticket number. If there is a ticket, make sure your PR title includes a conventional commit label. See existing PR titles for inspiration.
  • My work conforms to the OpenMRS 3.0 Styleguide and design documentation.
  • My work includes tests or is validated by existing tests.

Summary

O3-3937 Add test coverage around form readonly mode

Screenshots

Related Issue

https://openmrs.atlassian.net/browse/O3-3937

Other

Copy link

github-actions bot commented Sep 25, 2024

Size Change: 0 B

Total Size: 1.22 MB

ℹ️ View Unchanged
Filename Size
dist/151.js 378 kB
dist/225.js 2.57 kB
dist/277.js 1.84 kB
dist/300.js 642 B
dist/335.js 968 B
dist/343.js 253 kB
dist/353.js 3.02 kB
dist/41.js 3.37 kB
dist/420.js 108 kB
dist/422.js 6.8 kB
dist/540.js 2.63 kB
dist/55.js 758 B
dist/617.js 86.9 kB
dist/635.js 14.3 kB
dist/70.js 483 B
dist/901.js 11.8 kB
dist/99.js 691 B
dist/993.js 3.09 kB
dist/main.js 342 kB
dist/openmrs-esm-form-engine-lib.js 3.67 kB

compressed-size-action

@CynthiaKamau CynthiaKamau force-pushed the O3-3937 branch 4 times, most recently from 7a498c2 to 8f30422 Compare October 3, 2024 16:02
@@ -842,15 +844,68 @@ describe('Form engine component', () => {
});
});

function renderForm(formUUID, formJson, intent?: string) {
describe('Read only mode', () => {
it('should ascertain that each field with readonly = true passed will not be editable', async () => {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
it('should ascertain that each field with readonly = true passed will not be editable', async () => {
it('should ensure that each read-only field is not editable', async () => {', async () => {

});

describe('Form view mode', () => {
it('should ascertain that fields cannot be edited on view mode', async () => {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
it('should ascertain that fields cannot be edited on view mode', async () => {
it('should ensure that the form isn't editable in view mode', async () => {

Comment on lines +891 to +880
inputs.forEach((input) => {
expect(input).toHaveAttribute('readonly');
});
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you also assert that the "Save" button is disabled?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added it on line 884

Comment on lines +130 to +138
{
id: 'sampleQuestion',
label: 'Question title',
questionOptions: {
concept: '193e8a03-1581-46e9-b0a4-17c55fa2649f',
rendering: 'text',
},
type: 'obs',
},
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you need this?

Comment on lines +258 to +266
{
id: 'sampleQuestion',
label: 'Question title',
questionOptions: {
concept: '193e8a03-1581-46e9-b0a4-17c55fa2649f',
rendering: 'text',
},
type: 'obs',
},
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ditto

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Screenshot 2024-10-18 at 17 38 57

Removing this block brings this error

expect(visitTypeDropdown).toHaveClass('cds--list-box__field');

const visitTypeWrapper = visitTypeDropdown.closest('.cds--dropdown');
expect(visitTypeWrapper).toHaveClass('cds--dropdown cds--dropdown--readonly cds--list-box');
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What happens if the CSS names change? Can you use attributes instead?

@samuelmale samuelmale merged commit f996d05 into main Oct 23, 2024
4 checks passed
@samuelmale samuelmale deleted the O3-3937 branch October 23, 2024 20:11
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants