summaryrefslogtreecommitdiffstats
path: root/dom/html/test/forms/test_save_restore_radio_groups.html
blob: c5ef924a0e0614f2e4af7315f3a659292af1da14 (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
<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=350022
-->
<head>
  <title>Test for Bug 350022</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=350022">Mozilla Bug 350022</a>
<p id="display"></p>
<div id="content"><!-- style="display: none">-->
  <iframe src="save_restore_radio_groups.sjs"></iframe>
  <iframe src="save_restore_radio_groups.sjs"></iframe>
</div>
<pre id="test">
<script type="application/javascript">

/** Test for Bug 350022 **/

function checkRadioGroup(aFrame, aResults)
{
  var radios = frames[aFrame].document.getElementsByTagName('input');

  is(radios.length, aResults.length,
     "Radio group should have " + aResults.length + "elements");

  for (var i=0; i<aResults.length; ++i) {
    is(radios[i].checked, aResults[i],
       "Radio checked state should be " + aResults[i]);
  }
}

SimpleTest.waitForExplicitFinish();
addLoadEvent(function() {
  /**
   * We have two iframes each containing one radio button group.
   * We are going to change the selected radio button in one group.
   * Then, both iframes will be reloaded and the new groups will have another
   * radio checked by default.
   * For the first group (which had a selection change), nothing should change.
   * For the second, the selected radio button should change.
   */
  checkRadioGroup(0, [true, false, false]);
  checkRadioGroup(1, [true, false, false]);

  frames[0].document.getElementsByTagName('input')[2].checked = true;
  checkRadioGroup(0, [false, false, true]);

  framesElts = document.getElementsByTagName('iframe');
  framesElts[0].addEventListener("load", function() {
    checkRadioGroup(0, [false, false, true]);

    framesElts[1].addEventListener("load", function() {
      checkRadioGroup(1, [false, true, false]);
      SimpleTest.finish();
    }, {once: true});

    frames[1].location.reload();
  }, {once: true});

  frames[0].location.reload();
});

</script>
</pre>
</body>
</html>