|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419 |
- import { getFormValues, setFormValues } from '../../src';
- import * as utils from '../utils'
-
- describe('radio', () => {
- describe('basic', () => {
- beforeEach(utils.setup(`
- <!DOCTYPE html>
- <html lang="en-PH">
- <head>
- <meta charset="UTF-8">
- <title>Radio/Basic</title>
- </head>
- <body>
- <form>
- <label>
- <span>Hello</span>
- <input type="radio" name="enabled" />
- </label>
- <button type="submit">Submit</button>
- </form>
- </body>
- </html>
- `))
-
- it('should have no form values', () => {
- utils.test({
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- const before = utils.makeSearchParams(values)
- .toString();
- const after = utils.makeSearchParams(search)
- .toString();
- expect(values['enabled'])
- .toBeUndefined();
- expect(before)
- .toEqual(after);
- },
- expectedStaticValue: '',
- });
- });
- });
-
- describe('checked', () => {
- beforeEach(utils.setup(`
- <!DOCTYPE html>
- <html lang="en-PH">
- <head>
- <meta charset="UTF-8">
- <title>Radio/Checked</title>
- </head>
- <body>
- <form>
- <label>
- <span>Hello</span>
- <input type="radio" name="enabled" checked />
- </label>
- <button type="submit">Submit</button>
- </form>
- </body>
- </html>
- `))
-
- it('should have single form value on a single field', () => {
- utils.test({
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const before = utils.makeSearchParams(getFormValues(form, { submitter }))
- .toString();
- const after = utils.makeSearchParams(search)
- .toString();
- expect(before)
- .toEqual(after);
- },
- expectedStaticValue: 'enabled=on',
- });
- });
- });
-
- describe('duplicate', () => {
- beforeEach(utils.setup(`
- <!DOCTYPE html>
- <html lang="en-PH">
- <head>
- <meta charset="UTF-8">
- <title>Radio/Duplicate</title>
- </head>
- <body>
- <form>
- <label>
- <span>Hello 1</span>
- <input type="radio" name="enabled" value="hello 1" checked />
- </label>
- <label>
- <span>Hello 2</span>
- <input type="radio" name="enabled" value="hello 2" checked />
- </label>
- <label>
- <span>Hello 3</span>
- <input type="radio" name="enabled" value="hello 3" />
- </label>
- <label>
- <span>Hello 4</span>
- <input type="radio" name="enabled" value="hello 4" />
- </label>
- <button type="submit">Submit</button>
- </form>
- </body>
- </html>
- `));
-
- it('should get last value as checked', () => {
- utils.test({
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const before = utils.makeSearchParams(getFormValues(form, { submitter }))
- .toString();
- const after = utils.makeSearchParams(search)
- .toString();
- expect(before)
- .toEqual(after);
- },
- expectedStaticValue: {
- enabled: 'hello 2',
- },
- });
- });
-
- it('should set to last value', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, {
- enabled: ['hello 3', 'hello 4'],
- })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const before = utils.makeSearchParams(getFormValues(form, { submitter }))
- .toString();
- const after = utils.makeSearchParams(search)
- .toString();
- expect(before)
- .toEqual(after);
- },
- expectedStaticValue: {
- enabled: 'hello 4',
- },
- });
- });
- });
-
- describe('setting values', () => {
- beforeEach(utils.setup(`
- <!DOCTYPE html>
- <html lang="en-PH">
- <head>
- <meta charset="UTF-8">
- <title>Radio/Setting Values</title>
- </head>
- <body>
- <form>
- <label>
- <span>Hello</span>
- <input type="radio" name="enabled" value="default" checked />
- <input type="radio" name="enabled" />
- <input type="radio" name="enabled" value="true" />
- <input type="radio" name="enabled" value="yes" />
- <input type="radio" name="enabled" value="1" />
- <input type="radio" name="enabled" value="false" />
- <input type="radio" name="enabled" value="no" />
- <input type="radio" name="enabled" value="off" />
- <input type="radio" name="enabled" value="0" />
- <input type="radio" name="enabled" value="null" />
- </label>
- <button type="submit">Submit</button>
- </form>
- </body>
- </html>
- `))
-
- it('should uncheck for boolean "true"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: true, })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBeUndefined()
- },
- expectedStaticValue: '',
- });
- });
-
- it('should check for string "true"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 'true', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('true');
- },
- expectedStaticValue: 'enabled=true',
- });
- });
-
- it('should check for string "yes"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 'yes', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('yes');
- },
- expectedStaticValue: 'enabled=yes',
- });
- });
-
- it('should check for string "on"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 'on', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('on');
- },
- expectedStaticValue: 'enabled=on',
- });
- });
-
- it('should uncheck for boolean "false"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: false, })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBeUndefined()
- },
- expectedStaticValue: '',
- });
- });
-
- it('should check for string "false"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 'false', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('false');
- },
- expectedStaticValue: 'enabled=false',
- });
- });
-
- it('should check for string "no"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 'no', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('no')
- },
- expectedStaticValue: 'enabled=no',
- });
- });
-
- it('should check for string "off"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 'off', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('off');
- },
- expectedStaticValue: 'enabled=off',
- });
- });
-
- it('should uncheck for number "1"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 1, })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBeUndefined();
- },
- expectedStaticValue: '',
- });
- });
-
- it('should check for string "1"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: '1', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('1');
- },
- expectedStaticValue: 'enabled=1',
- });
- });
-
- it('should uncheck for number "0"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 0, })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBeUndefined()
- },
- expectedStaticValue: '',
- });
- });
-
- it('should check for string "0"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: '0', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('0')
- },
- expectedStaticValue: 'enabled=0',
- });
- });
-
- it('should uncheck for object "null"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: null, })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBeUndefined()
- },
- expectedStaticValue: '',
- });
- });
-
- it('should check for string "null"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: 'null', })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('null');
- },
- expectedStaticValue: 'null',
- });
- });
-
- it('should check for boolean "true"', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: true, })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBeUndefined()
- },
- expectedStaticValue: '',
- });
- });
-
- it('should check valueless radio for last value on', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: ['foo', 'bar', 'baz', 'on'], })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('on')
- },
- expectedStaticValue: 'enabled=on',
- });
- });
-
- it('should check radio with value for last value', () => {
- utils.test({
- onLoaded: (form: HTMLFormElement) => {
- setFormValues(form, { enabled: ['foo', 'bar', 'baz', 'on', 'default', 'true'], })
- },
- actionBeforeSubmit: (cy: any) => cy.get('[type="submit"]'),
- onSubmitted: (form: HTMLFormElement, submitter: any, search: any) => {
- const values = getFormValues(form, { submitter })
- expect(values['enabled']).toBe('true')
- },
- expectedStaticValue: 'enabled=true',
- });
- });
- });
- });
|