UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

241 lines (237 loc) 9.24 kB
"use strict"; var import_vitest = require("vitest"); function _assert_this_initialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _call_super(_this, derived, args) { derived = _get_prototype_of(derived); return _possible_constructor_return(_this, _is_native_reflect_construct() ? Reflect.construct(derived, args || [], _get_prototype_of(_this).constructor) : derived.apply(_this, args)); } function _class_call_check(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _construct(Parent, args, Class) { if (_is_native_reflect_construct()) { _construct = Reflect.construct; } else { _construct = function construct(Parent2, args2, Class2) { var a = [null]; a.push.apply(a, args2); var Constructor = Function.bind.apply(Parent2, a); var instance = new Constructor(); if (Class2) _set_prototype_of(instance, Class2.prototype); return instance; }; } return _construct.apply(null, arguments); } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _create_class(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _get_prototype_of(o) { _get_prototype_of = Object.setPrototypeOf ? Object.getPrototypeOf : function getPrototypeOf(o2) { return o2.__proto__ || Object.getPrototypeOf(o2); }; return _get_prototype_of(o); } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _set_prototype_of(subClass, superClass); } function _is_native_function(fn) { return Function.toString.call(fn).indexOf("[native code]") !== -1; } function _possible_constructor_return(self, call) { if (call && (_type_of(call) === "object" || typeof call === "function")) { return call; } return _assert_this_initialized(self); } function _set_prototype_of(o, p) { _set_prototype_of = Object.setPrototypeOf || function setPrototypeOf(o2, p2) { o2.__proto__ = p2; return o2; }; return _set_prototype_of(o, p); } function _type_of(obj) { "@swc/helpers - typeof"; return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj; } function _wrap_native_super(Class) { var _cache = typeof Map === "function" ? /* @__PURE__ */new Map() : void 0; _wrap_native_super = function wrapNativeSuper(Class2) { if (Class2 === null || !_is_native_function(Class2)) return Class2; if (typeof Class2 !== "function") { throw new TypeError("Super expression must either be null or a function"); } if (typeof _cache !== "undefined") { if (_cache.has(Class2)) return _cache.get(Class2); _cache.set(Class2, Wrapper); } function Wrapper() { return _construct(Class2, arguments, _get_prototype_of(this).constructor); } Wrapper.prototype = Object.create(Class2.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _set_prototype_of(Wrapper, Class2); }; return _wrap_native_super(Class); } function _is_native_reflect_construct() { try { var result = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (_) {} return (_is_native_reflect_construct = function () { return !!result; })(); } var ReadOnlyURLSearchParams = /* @__PURE__ */function (URLSearchParams1) { "use strict"; _inherits(ReadOnlyURLSearchParams2, URLSearchParams1); function ReadOnlyURLSearchParams2() { _class_call_check(this, ReadOnlyURLSearchParams2); return _call_super(this, ReadOnlyURLSearchParams2, arguments); } _create_class(ReadOnlyURLSearchParams2, [{ key: "set", value: function set(_name, _value) { throw new Error("useSearchParams returns a read-only URLSearchParams object"); } }, { key: "append", value: function append(_name, _value) { throw new Error("useSearchParams returns a read-only URLSearchParams object"); } }, { key: "delete", value: function _delete(_name, _value) { throw new Error("useSearchParams returns a read-only URLSearchParams object"); } }]); return ReadOnlyURLSearchParams2; }(_wrap_native_super(URLSearchParams)); (0, import_vitest.describe)("ReadOnlyURLSearchParams", function () { (0, import_vitest.it)("should allow reading values", function () { var params = new ReadOnlyURLSearchParams([["sort", "price"], ["category", "electronics"]]); (0, import_vitest.expect)(params.get("sort")).toBe("price"); (0, import_vitest.expect)(params.get("category")).toBe("electronics"); (0, import_vitest.expect)(params.get("nonexistent")).toBe(null); }); (0, import_vitest.it)("should support has()", function () { var params = new ReadOnlyURLSearchParams([["key", "value"]]); (0, import_vitest.expect)(params.has("key")).toBe(true); (0, import_vitest.expect)(params.has("missing")).toBe(false); }); (0, import_vitest.it)("should support getAll() for repeated params", function () { var params = new ReadOnlyURLSearchParams([["tag", "a"], ["tag", "b"], ["tag", "c"]]); (0, import_vitest.expect)(params.getAll("tag")).toEqual(["a", "b", "c"]); }); (0, import_vitest.it)("should support iteration", function () { var params = new ReadOnlyURLSearchParams([["a", "1"], ["b", "2"]]); var entries = Array.from(params.entries()); (0, import_vitest.expect)(entries).toEqual([["a", "1"], ["b", "2"]]); }); (0, import_vitest.it)("should support toString()", function () { var params = new ReadOnlyURLSearchParams([["sort", "price"], ["page", "1"]]); (0, import_vitest.expect)(params.toString()).toBe("sort=price&page=1"); }); (0, import_vitest.it)("should throw on set()", function () { var params = new ReadOnlyURLSearchParams([["key", "value"]]); (0, import_vitest.expect)(function () { return params.set("key", "new"); }).toThrow("useSearchParams returns a read-only URLSearchParams object"); }); (0, import_vitest.it)("should throw on append()", function () { var params = new ReadOnlyURLSearchParams([["key", "value"]]); (0, import_vitest.expect)(function () { return params.append("key", "another"); }).toThrow("useSearchParams returns a read-only URLSearchParams object"); }); (0, import_vitest.it)("should throw on delete()", function () { var params = new ReadOnlyURLSearchParams([["key", "value"]]); (0, import_vitest.expect)(function () { return params.delete("key"); }).toThrow("useSearchParams returns a read-only URLSearchParams object"); }); }); (0, import_vitest.describe)("useSearchParams param conversion", function () { function paramsToEntries(params) { return Object.entries(params).flatMap(function (param) { var [key, value] = param; if (value === void 0) return []; return Array.isArray(value) ? value.map(function (v) { return [key, String(v)]; }) : [[key, String(value)]]; }); } (0, import_vitest.it)("should convert simple string params", function () { var params = { sort: "price", page: "1" }; var entries = paramsToEntries(params); (0, import_vitest.expect)(entries).toEqual([["sort", "price"], ["page", "1"]]); }); (0, import_vitest.it)("should expand array params into multiple entries", function () { var params = { tags: ["a", "b", "c"] }; var entries = paramsToEntries(params); (0, import_vitest.expect)(entries).toEqual([["tags", "a"], ["tags", "b"], ["tags", "c"]]); }); (0, import_vitest.it)("should filter out undefined values", function () { var params = { present: "yes", missing: void 0 }; var entries = paramsToEntries(params); (0, import_vitest.expect)(entries).toEqual([["present", "yes"]]); }); (0, import_vitest.it)("should handle mixed params", function () { var params = { single: "value", multiple: ["x", "y"], absent: void 0 }; var entries = paramsToEntries(params); (0, import_vitest.expect)(entries).toEqual([["single", "value"], ["multiple", "x"], ["multiple", "y"]]); }); (0, import_vitest.it)("should handle empty params", function () { var params = {}; var entries = paramsToEntries(params); (0, import_vitest.expect)(entries).toEqual([]); }); }); //# sourceMappingURL=hooks.test.native.js.map