11cb0ef41Sopenharmony_ci// Copyright Joyent, Inc. and other Node contributors.
21cb0ef41Sopenharmony_ci//
31cb0ef41Sopenharmony_ci// Permission is hereby granted, free of charge, to any person obtaining a
41cb0ef41Sopenharmony_ci// copy of this software and associated documentation files (the
51cb0ef41Sopenharmony_ci// "Software"), to deal in the Software without restriction, including
61cb0ef41Sopenharmony_ci// without limitation the rights to use, copy, modify, merge, publish,
71cb0ef41Sopenharmony_ci// distribute, sublicense, and/or sell copies of the Software, and to permit
81cb0ef41Sopenharmony_ci// persons to whom the Software is furnished to do so, subject to the
91cb0ef41Sopenharmony_ci// following conditions:
101cb0ef41Sopenharmony_ci//
111cb0ef41Sopenharmony_ci// The above copyright notice and this permission notice shall be included
121cb0ef41Sopenharmony_ci// in all copies or substantial portions of the Software.
131cb0ef41Sopenharmony_ci//
141cb0ef41Sopenharmony_ci// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
151cb0ef41Sopenharmony_ci// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
161cb0ef41Sopenharmony_ci// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
171cb0ef41Sopenharmony_ci// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
181cb0ef41Sopenharmony_ci// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
191cb0ef41Sopenharmony_ci// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
201cb0ef41Sopenharmony_ci// USE OR OTHER DEALINGS IN THE SOFTWARE.
211cb0ef41Sopenharmony_ci
221cb0ef41Sopenharmony_ci'use strict';
231cb0ef41Sopenharmony_ci
241cb0ef41Sopenharmony_ci// Flags: --expose-internals
251cb0ef41Sopenharmony_ci
261cb0ef41Sopenharmony_cirequire('../common');
271cb0ef41Sopenharmony_ciconst assert = require('assert');
281cb0ef41Sopenharmony_ciconst L = require('internal/linkedlist');
291cb0ef41Sopenharmony_ci
301cb0ef41Sopenharmony_ciconst list = { name: 'list' };
311cb0ef41Sopenharmony_ciconst A = { name: 'A' };
321cb0ef41Sopenharmony_ciconst B = { name: 'B' };
331cb0ef41Sopenharmony_ciconst C = { name: 'C' };
341cb0ef41Sopenharmony_ciconst D = { name: 'D' };
351cb0ef41Sopenharmony_ci
361cb0ef41Sopenharmony_ci
371cb0ef41Sopenharmony_ciL.init(list);
381cb0ef41Sopenharmony_ciL.init(A);
391cb0ef41Sopenharmony_ciL.init(B);
401cb0ef41Sopenharmony_ciL.init(C);
411cb0ef41Sopenharmony_ciL.init(D);
421cb0ef41Sopenharmony_ci
431cb0ef41Sopenharmony_ciassert.ok(L.isEmpty(list));
441cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), null);
451cb0ef41Sopenharmony_ci
461cb0ef41Sopenharmony_ciL.append(list, A);
471cb0ef41Sopenharmony_ci// list -> A
481cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), A);
491cb0ef41Sopenharmony_ci
501cb0ef41Sopenharmony_ciL.append(list, B);
511cb0ef41Sopenharmony_ci// list -> A -> B
521cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), A);
531cb0ef41Sopenharmony_ci
541cb0ef41Sopenharmony_ciL.append(list, C);
551cb0ef41Sopenharmony_ci// list -> A -> B -> C
561cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), A);
571cb0ef41Sopenharmony_ci
581cb0ef41Sopenharmony_ciL.append(list, D);
591cb0ef41Sopenharmony_ci// list -> A -> B -> C -> D
601cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), A);
611cb0ef41Sopenharmony_ci
621cb0ef41Sopenharmony_ciL.remove(A);
631cb0ef41Sopenharmony_ciL.remove(B);
641cb0ef41Sopenharmony_ci// B is already removed, so removing it again shouldn't hurt.
651cb0ef41Sopenharmony_ciL.remove(B);
661cb0ef41Sopenharmony_ci// list -> C -> D
671cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), C);
681cb0ef41Sopenharmony_ci
691cb0ef41Sopenharmony_ci// Put B back on the list
701cb0ef41Sopenharmony_ciL.append(list, B);
711cb0ef41Sopenharmony_ci// list -> C -> D -> B
721cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), C);
731cb0ef41Sopenharmony_ci
741cb0ef41Sopenharmony_ciL.remove(C);
751cb0ef41Sopenharmony_ci// list -> D -> B
761cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), D);
771cb0ef41Sopenharmony_ci
781cb0ef41Sopenharmony_ciL.remove(B);
791cb0ef41Sopenharmony_ci// list -> D
801cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), D);
811cb0ef41Sopenharmony_ci
821cb0ef41Sopenharmony_ciL.remove(D);
831cb0ef41Sopenharmony_ci// list
841cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), null);
851cb0ef41Sopenharmony_ci
861cb0ef41Sopenharmony_ci
871cb0ef41Sopenharmony_ciassert.ok(L.isEmpty(list));
881cb0ef41Sopenharmony_ci
891cb0ef41Sopenharmony_ci
901cb0ef41Sopenharmony_ciL.append(list, D);
911cb0ef41Sopenharmony_ci// list -> D
921cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), D);
931cb0ef41Sopenharmony_ci
941cb0ef41Sopenharmony_ciL.append(list, C);
951cb0ef41Sopenharmony_ciL.append(list, B);
961cb0ef41Sopenharmony_ciL.append(list, A);
971cb0ef41Sopenharmony_ci// list -> D -> C -> B -> A
981cb0ef41Sopenharmony_ci
991cb0ef41Sopenharmony_ci// Append should REMOVE C from the list and append it to the end.
1001cb0ef41Sopenharmony_ciL.append(list, C);
1011cb0ef41Sopenharmony_ci// list -> D -> B -> A -> C
1021cb0ef41Sopenharmony_ci
1031cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(list), D);
1041cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(D), B);
1051cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(B), A);
1061cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(A), C);
1071cb0ef41Sopenharmony_ciassert.strictEqual(L.peek(C), list);
108