| asynctest(
  'browser.core.DataAttributeTest',
  [
    'ephox.agar.api.GeneralSteps',
    'ephox.agar.api.Pipeline',
    'ephox.mcagar.api.TinyApis',
    'ephox.mcagar.api.TinyLoader',
    'ephox.mcagar.api.TinyUi',
    'tinymce.plugins.media.Plugin',
    'tinymce.plugins.media.test.Utils',
    'tinymce.themes.modern.Theme'
  ],
  function (GeneralSteps, Pipeline, TinyApis, TinyLoader, TinyUi, Plugin, Utils, Theme) {
    var success = arguments[arguments.length - 2];
    var failure = arguments[arguments.length - 1];
    Plugin();
    Theme();
    var sTestEmbedContentFromUrlWithAttribute = function (ui, url, content) {
      return GeneralSteps.sequence([
        Utils.sOpenDialog(ui),
        Utils.sPasteSourceValue(ui, url),
        Utils.sAssertEmbedContent(ui, content),
        Utils.sSubmitAndReopen(ui),
        Utils.sAssertSourceValue(ui, url),
        Utils.sCloseDialog(ui)
      ]);
    };
    var sTestEmbedContentFromUrl2 = function (ui, url, url2, content, content2) {
      return GeneralSteps.sequence([
        Utils.sOpenDialog(ui),
        Utils.sPasteSourceValue(ui, url),
        Utils.sAssertEmbedContent(ui, content),
        Utils.sSubmitAndReopen(ui),
        Utils.sAssertSourceValue(ui, url),
        Utils.sPasteSourceValue(ui, url2),
        Utils.sAssertEmbedContent(ui, content2),
        Utils.sCloseDialog(ui)
      ]);
    };
    TinyLoader.setup(function (editor, onSuccess, onFailure) {
      var ui = TinyUi(editor);
      var api = TinyApis(editor);
      Pipeline.async({}, [
        sTestEmbedContentFromUrlWithAttribute(ui,
          'a',
          '<div data-ephox-embed-iri="a" style="max-width: 300px; max-height: 150px"></div>'
        ),
        sTestEmbedContentFromUrl2(ui, 'a', 'b',
          '<div data-ephox-embed-iri="a" style="max-width: 300px; max-height: 150px"></div>',
          '<div data-ephox-embed-iri="b" style="max-width: 300px; max-height: 150px"></div>'
        ),
        Utils.sTestEmbedContentFromUrl(ui,
          'a',
          '<div data-ephox-embed-iri="a" style="max-width: 300px; max-height: 150px"></div>'
        ),
        Utils.sAssertSizeRecalcConstrained(ui),
        Utils.sAssertSizeRecalcUnconstrained(ui),
        api.sSetContent(''),
        Utils.sAssertSizeRecalcConstrainedReopen(ui, api)
      ], onSuccess, onFailure);
    }, {
      plugins: ["media"],
      toolbar: "media",
      media_url_resolver: function (data, resolve) {
        resolve({ html: '<div data-ephox-embed-iri="' + data.url + '" style="max-width: 300px; max-height: 150px"></div>' });
      },
      skin_url: '/project/src/skins/lightgray/dist/lightgray'
    }, success, failure);
  }
);
 |