| asynctest(
  'browser.tinymce.core.keyboard.EnterKeyCeFalseTest',
  [
    'ephox.agar.api.Pipeline',
    'ephox.mcagar.api.LegacyUnit',
    'ephox.mcagar.api.TinyLoader',
    'tinymce.core.Env',
    'tinymce.core.test.HtmlUtils',
    'tinymce.core.util.Tools',
    'tinymce.themes.modern.Theme'
  ],
  function (Pipeline, LegacyUnit, TinyLoader, Env, HtmlUtils, Tools, Theme) {
    var success = arguments[arguments.length - 2];
    var failure = arguments[arguments.length - 1];
    var suite = LegacyUnit.createSuite();
    Theme();
    var pressEnter = function (editor, evt) {
      var dom = editor.dom, target = editor.selection.getNode();
      evt = Tools.extend({ keyCode: 13 }, evt);
      dom.fire(target, 'keydown', evt);
      dom.fire(target, 'keypress', evt);
      dom.fire(target, 'keyup', evt);
    };
    suite.test('Enter in text within contentEditable:true h1 inside contentEditable:false div', function (editor) {
      editor.getBody().innerHTML = '<div contenteditable="false"><h1 contenteditable="true">ab</h1></div>';
      LegacyUnit.setSelection(editor, 'div h1', 1);
      pressEnter(editor);
      LegacyUnit.equal(
        HtmlUtils.cleanHtml(editor.getBody().innerHTML),
        '<div contenteditable="false"><h1 contenteditable="true">ab</h1></div>'
      );
    });
    suite.test('Enter before cE=false div', function (editor) {
      editor.getBody().innerHTML = '<div contenteditable="false">x</div>';
      editor.selection.select(editor.dom.select('div')[0]);
      editor.selection.collapse(true);
      pressEnter(editor);
      LegacyUnit.equal(
        HtmlUtils.cleanHtml(editor.getBody().innerHTML),
        '<p><br data-mce-bogus="1"></p><div contenteditable="false">x</div>'
      );
      LegacyUnit.equal(editor.selection.getNode().nodeName, 'P');
    });
    suite.test('Enter after cE=false div', function (editor) {
      editor.getBody().innerHTML = '<div contenteditable="false">x</div>';
      editor.selection.select(editor.dom.select('div')[0]);
      editor.selection.collapse(false);
      pressEnter(editor);
      LegacyUnit.equal(
        HtmlUtils.cleanHtml(editor.getBody().innerHTML),
        '<div contenteditable="false">x</div><p><br data-mce-bogus="1"></p>'
      );
      LegacyUnit.equal(editor.selection.getNode().nodeName, 'P');
    });
    TinyLoader.setup(function (editor, onSuccess, onFailure) {
      Pipeline.async({}, suite.toSteps(editor), onSuccess, onFailure);
    }, {
      add_unload_trigger: false,
      disable_nodechange: true,
      schema: 'html5',
      extended_valid_elements: 'div[id|style|contenteditable],span[id|style|contenteditable],#dt,#dd',
      entities: 'raw',
      indent: false,
      skin_url: '/project/src/skins/lightgray/dist/lightgray'
    }, success, failure);
  }
);
 |