Test getRangeAt() returning the same object (#29773)

* Test getRangeAt() returning the same object

* add test for different ranges

* add no range test

* syntax update
diff --git a/selection/getRangeAt.html b/selection/getRangeAt.html
index 466bfd5..a84ad46 100644
--- a/selection/getRangeAt.html
+++ b/selection/getRangeAt.html
@@ -1,14 +1,32 @@
 <!DOCTYPE html>
 <title>The getRangeAt method</title>
-<div id=log></div>
 <script src=/resources/testharness.js></script>
 <script src=/resources/testharnessreport.js></script>
+<link rel="help" href="https://w3c.github.io/selection-api/#dom-selection-getrangeat">
+<body>
 <script>
+const sel = getSelection();
+
 test(function() {
-  var sel = getSelection();
   var range = document.createRange();
   sel.addRange(range);
   assert_throws_dom("INDEX_SIZE_ERR", function() { sel.getRangeAt(-1); })
   assert_throws_dom("INDEX_SIZE_ERR", function() { sel.getRangeAt(1); })
-});
+}, "Only supports index 0");
+
+test(() => {
+  sel.removeAllRanges();
+  assert_throws_dom("INDEX_SIZE_ERR", () => sel.getRangeAt(0))
+}, "Throws when with no range");
+
+test(() => {
+  sel.addRange(document.createRange());
+  assert_equals(sel.getRangeAt(0), sel.getRangeAt(0));
+}, "Returns the same range object when with no selection change");
+
+test(() => {
+  const range = sel.getRangeAt(0);
+  sel.collapse(document.body);
+  assert_not_equals(range, sel.getRangeAt(0));
+}, "Returns a different range object when with selection change");
 </script>