chromium/third_party/google-closure-library/closure/goog/ui/nativebuttonrenderer_test.js

/**
 * @license
 * Copyright The Closure Library Authors.
 * SPDX-License-Identifier: Apache-2.0
 */

goog.module('goog.ui.NativeButtonRendererTest');
goog.setTestOnly();

const Button = goog.require('goog.ui.Button');
const Component = goog.require('goog.ui.Component');
const ExpectedFailures = goog.require('goog.testing.ExpectedFailures');
const NativeButtonRenderer = goog.require('goog.ui.NativeButtonRenderer');
const TagName = goog.require('goog.dom.TagName');
const classlist = goog.require('goog.dom.classlist');
const dom = goog.require('goog.dom');
const events = goog.require('goog.events');
const rendererasserts = goog.require('goog.testing.ui.rendererasserts');
const testSuite = goog.require('goog.testing.testSuite');
const testingEvents = goog.require('goog.testing.events');
const userAgent = goog.require('goog.userAgent');

let sandbox;
let renderer;
let expectedFailures;
let button;

testSuite({
  setUpPage() {
    sandbox = dom.getElement('sandbox');
    renderer = NativeButtonRenderer.getInstance();
    expectedFailures = new ExpectedFailures();
  },

  setUp() {
    button = new Button('Hello', renderer);
  },

  tearDown() {
    button.dispose();
    dom.removeChildren(sandbox);
    expectedFailures.handleTearDown();
  },

  testConstructor() {
    assertNotNull('Renderer must not be null', renderer);
  },

  testGetAriaRole() {
    assertUndefined('ARIA role must be undefined', renderer.getAriaRole());
  },

  testCreateDom() {
    button.setTooltip('Hello, world!');
    button.setValue('foo');
    const element = renderer.createDom(button);
    assertNotNull('Element must not be null', element);
    assertEquals(
        'Element must be a button', String(TagName.BUTTON), element.tagName);
    assertSameElements(
        'Button element must have expected class name', ['goog-button'],
        classlist.get(element));
    assertFalse('Button element must be enabled', element.disabled);
    assertEquals(
        'Button element must have expected title', 'Hello, world!',
        element.title);
    // Expected to fail on IE.
    expectedFailures.expectFailureFor(userAgent.IE);
    try {
      // See http://www.fourmilab.ch/fourmilog/archives/2007-03/000824.html
      // for a description of the problem.
      assertEquals(
          'Button element must have expected value', 'foo', element.value);
      assertEquals(
          'Button element must have expected contents', 'Hello',
          element.innerHTML);
    } catch (e) {
      expectedFailures.handleException(e);
    }
    assertFalse(
        'Button must not handle its own mouse events',
        button.isHandleMouseEvents());
    assertFalse(
        'Button must not support the custom FOCUSED state',
        button.isSupportedState(Component.State.FOCUSED));
  },

  testCanDecorate() {
    sandbox.innerHTML = '<button id="buttonElement">Button</button>\n' +
        '<input id="inputButton" type="button" value="Input Button">\n' +
        '<input id="inputSubmit" type="submit" value="Input Submit">\n' +
        '<input id="inputReset" type="reset" value="Input Reset">\n' +
        '<input id="inputText" type="text" size="10">\n' +
        '<div id="divButton" class="goog-button">Hello</div>';

    assertTrue(
        'Must be able to decorate <button>',
        renderer.canDecorate(dom.getElement('buttonElement')));
    assertTrue(
        'Must be able to decorate <input type="button">',
        renderer.canDecorate(dom.getElement('inputButton')));
    assertTrue(
        'Must be able to decorate <input type="submit">',
        renderer.canDecorate(dom.getElement('inputSubmit')));
    assertTrue(
        'Must be able to decorate <input type="reset">',
        renderer.canDecorate(dom.getElement('inputReset')));
    assertFalse(
        'Must not be able to decorate <input type="text">',
        renderer.canDecorate(dom.getElement('inputText')));
    assertFalse(
        'Must not be able to decorate <div class="goog-button">',
        renderer.canDecorate(dom.getElement('divButton')));
  },

  testDecorate() {
    sandbox.innerHTML =
        '<button id="foo" title="Hello!" value="bar">Foo Button</button>\n' +
        '<button id="disabledButton" value="bah" disabled="disabled">Disabled' +
        '</button>';

    let element = renderer.decorate(button, dom.getElement('foo'));
    assertEquals(
        'Decorated element must be as expected', dom.getElement('foo'),
        element);
    assertEquals(
        'Decorated button title must have expected value', 'Hello!',
        button.getTooltip());
    // Expected to fail on IE.
    expectedFailures.expectFailureFor(userAgent.IE);
    try {
      // See http://www.fourmilab.ch/fourmilog/archives/2007-03/000824.html
      // for a description of the problem.
      assertEquals(
          'Decorated button value must have expected value', 'bar',
          button.getValue());
    } catch (e) {
      expectedFailures.handleException(e);
    }
    assertFalse(
        'Button must not handle its own mouse events',
        button.isHandleMouseEvents());
    assertFalse(
        'Button must not support the custom FOCUSED state',
        button.isSupportedState(Component.State.FOCUSED));

    element = renderer.decorate(button, dom.getElement('disabledButton'));
    assertFalse('Decorated button must be disabled', button.isEnabled());
    assertSameElements(
        'Decorated button must have expected class names',
        ['goog-button', 'goog-button-disabled'], classlist.get(element));
    // Expected to fail on IE.
    expectedFailures.expectFailureFor(userAgent.IE);
    try {
      // See http://www.fourmilab.ch/fourmilog/archives/2007-03/000824.html
      // for a description of the problem.
      assertEquals(
          'Decorated button value must have expected value', 'bah',
          button.getValue());
    } catch (e) {
      expectedFailures.handleException(e);
    }
    assertFalse(
        'Button must not handle its own mouse events',
        button.isHandleMouseEvents());
    assertFalse(
        'Button must not support the custom FOCUSED state',
        button.isSupportedState(Component.State.FOCUSED));
  },

  testInitializeDom() {
    let dispatchedActionCount = 0;
    const handleAction = () => {
      dispatchedActionCount++;
    };
    events.listen(button, Component.EventType.ACTION, handleAction);

    button.render(sandbox);
    testingEvents.fireClickSequence(button.getElement());
    assertEquals(
        'Button must have dispatched ACTION on click', 1,
        dispatchedActionCount);

    events.unlisten(button, Component.EventType.ACTION, handleAction);
  },

  testIsFocusable() {
    assertTrue(
        'Enabled button must be focusable', renderer.isFocusable(button));
    button.setEnabled(false);
    assertFalse(
        'Disabled button must not be focusable', renderer.isFocusable(button));
  },

  testSetState() {
    button.render(sandbox);
    assertFalse(
        'Button element must not be disabled', button.getElement().disabled);
    renderer.setState(button, Component.State.DISABLED, true);
    assertTrue('Button element must be disabled', button.getElement().disabled);
  },

  testGetValue() {
    sandbox.innerHTML = '<button id="foo" value="blah">Hello</button>';
    // Expected to fail on IE.
    expectedFailures.expectFailureFor(userAgent.IE);
    try {
      // See http://www.fourmilab.ch/fourmilog/archives/2007-03/000824.html
      // for a description of the problem.
      assertEquals(
          'Value must be as expected', 'blah',
          renderer.getValue(dom.getElement('foo')));
    } catch (e) {
      expectedFailures.handleException(e);
    }
  },

  testSetValue() {
    button.render(sandbox);
    renderer.setValue(button.getElement(), 'What?');
    assertEquals(
        'Button must have expected value', 'What?',
        renderer.getValue(button.getElement()));
  },

  testDoesntCallGetCssClassInConstructor() {
    rendererasserts.assertNoGetCssClassCallsInConstructor(NativeButtonRenderer);
  },
});