summaryrefslogtreecommitdiffstats
path: root/devtools/client/shared/test/browser_inplace-editor-02.js
blob: 9ecb0bca0243d1dedd66085437479098da8032c9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */
/* import-globals-from helper_inplace_editor.js */

"use strict";

loadHelperScript("helper_inplace_editor.js");

// Test that the trimOutput option for the inplace editor works correctly.

add_task(async function () {
  await addTab("data:text/html;charset=utf-8,inline editor tests");
  const { host, doc } = await createHost();

  await testNonTrimmed(doc);
  await testTrimmed(doc);

  host.destroy();
  gBrowser.removeCurrentTab();
});

function testNonTrimmed(doc) {
  info("Testing the trimOutput=false option");
  return new Promise(resolve => {
    const initial = "\nMultiple\nLines\n";
    const changed = " \nMultiple\nLines\n with more whitespace ";
    createInplaceEditorAndClick(
      {
        trimOutput: false,
        multiline: true,
        initial,
        start(editor) {
          is(
            editor.input.value,
            initial,
            "Explicit initial value should be used."
          );
          editor.input.value = changed;
          EventUtils.sendKey("return");
        },
        done: onDone(changed, true, resolve),
      },
      doc
    );
  });
}

function testTrimmed(doc) {
  info("Testing the trimOutput=true option (default value)");
  return new Promise(resolve => {
    const initial = "\nMultiple\nLines\n";
    const changed = " \nMultiple\nLines\n with more whitespace ";
    createInplaceEditorAndClick(
      {
        initial,
        multiline: true,
        start(editor) {
          is(
            editor.input.value,
            initial,
            "Explicit initial value should be used."
          );
          editor.input.value = changed;
          EventUtils.sendKey("return");
        },
        done: onDone(changed.trim(), true, resolve),
      },
      doc
    );
  });
}

function onDone(value, isCommit, resolve) {
  return function (actualValue, actualCommit) {
    info("Inplace-editor's done callback executed, checking its state");
    is(actualValue, value, "The value is correct");
    is(actualCommit, isCommit, "The commit boolean is correct");
    resolve();
  };
}