From 16209ee17a08b5caf1778d6c4f4d30a024dd2b0e Mon Sep 17 00:00:00 2001 From: David King Date: Tue, 15 Mar 2022 10:27:49 +0000 Subject: [PATCH] Update to 1.71.90 --- .gitignore | 1 + gjs-1.71.1-bigint-32bit-test.patch | 46 ----- gjs-1.71.1-cairo-textextents-test.patch | 33 --- gjs-1.71.1-promise-rejection.patch | 258 ------------------------ gjs.spec | 13 +- sources | 2 +- 6 files changed, 7 insertions(+), 346 deletions(-) delete mode 100644 gjs-1.71.1-bigint-32bit-test.patch delete mode 100644 gjs-1.71.1-cairo-textextents-test.patch delete mode 100644 gjs-1.71.1-promise-rejection.patch diff --git a/.gitignore b/.gitignore index c62df3f..162d17d 100644 --- a/.gitignore +++ b/.gitignore @@ -125,3 +125,4 @@ gjs-0.7.1.tar.gz /gjs-1.70.0.tar.xz /gjs-1.70.1.tar.xz /gjs-1.71.1.tar.xz +/gjs-1.71.90.tar.xz diff --git a/gjs-1.71.1-bigint-32bit-test.patch b/gjs-1.71.1-bigint-32bit-test.patch deleted file mode 100644 index e26c2e9..0000000 --- a/gjs-1.71.1-bigint-32bit-test.patch +++ /dev/null @@ -1,46 +0,0 @@ -From a81be96706588c69ebad5c310ddb050b73831ae6 Mon Sep 17 00:00:00 2001 -From: Philip Chimento -Date: Sun, 20 Feb 2022 17:31:57 -0800 -Subject: [PATCH] tests: Fix BigInt tests on 32-bit - -Since we test BigInt values for each type that has a key in the -BigIntLimits object, we need to not define keys for types that are not -64-bits. ---- - installed-tests/js/testGIMarshalling.js | 8 ++------ - 1 file changed, 2 insertions(+), 6 deletions(-) - -diff --git a/installed-tests/js/testGIMarshalling.js b/installed-tests/js/testGIMarshalling.js -index 02c03f0f9..1f13b311f 100644 ---- a/installed-tests/js/testGIMarshalling.js -+++ b/installed-tests/js/testGIMarshalling.js -@@ -141,10 +141,6 @@ const BigIntLimits = { - max: 2n ** 63n - 1n, - umax: 2n ** 64n - 1n, - }, -- long: {}, -- ssize: { -- utype: 'size', -- }, - }; - - Object.assign(Limits.short, Limits.int16); -@@ -152,13 +148,13 @@ Object.assign(Limits.int, Limits.int32); - // Platform dependent sizes; expand definitions as needed - if (GLib.SIZEOF_LONG === 8) { - Object.assign(Limits.long, Limits.int64); -- Object.assign(BigIntLimits.long, BigIntLimits.int64); -+ BigIntLimits.long = Object.assign({}, BigIntLimits.int64); - } else { - Object.assign(Limits.long, Limits.int32); - } - if (GLib.SIZEOF_SSIZE_T === 8) { - Object.assign(Limits.ssize, Limits.int64); -- Object.assign(BigIntLimits.ssize, BigIntLimits.int64); -+ BigIntLimits.ssize = Object.assign({utype: 'size'}, BigIntLimits.int64); - } else { - Object.assign(Limits.ssize, Limits.int32); - } --- -GitLab - diff --git a/gjs-1.71.1-cairo-textextents-test.patch b/gjs-1.71.1-cairo-textextents-test.patch deleted file mode 100644 index 313c051..0000000 --- a/gjs-1.71.1-cairo-textextents-test.patch +++ /dev/null @@ -1,33 +0,0 @@ -From 33a0fef9cc9103f873aa45dbdcb4fe99c2fffecb Mon Sep 17 00:00:00 2001 -From: Philip Chimento -Date: Tue, 15 Feb 2022 17:30:42 -0800 -Subject: [PATCH] test: Relax assertion in cr.textExtents() - -These three values seem to be DPI-dependent, so let's just make sure they -are numbers instead of any particular number. - -Closes: #461 ---- - installed-tests/js/testCairo.js | 6 +++--- - 1 file changed, 3 insertions(+), 3 deletions(-) - -diff --git a/installed-tests/js/testCairo.js b/installed-tests/js/testCairo.js -index 186d0519d..c0c6d119f 100644 ---- a/installed-tests/js/testCairo.js -+++ b/installed-tests/js/testCairo.js -@@ -117,9 +117,9 @@ describe('Cairo', function () { - expect(cr.textExtents('trailing spaces ')).toEqual({ - xBearing: 0, - yBearing: -8, -- width: 72, -- height: 10, -- xAdvance: 81, -+ width: jasmine.any(Number), -+ height: jasmine.any(Number), -+ xAdvance: jasmine.any(Number), - yAdvance: 0, - }); - }); --- -GitLab - diff --git a/gjs-1.71.1-promise-rejection.patch b/gjs-1.71.1-promise-rejection.patch deleted file mode 100644 index 7dfd077..0000000 --- a/gjs-1.71.1-promise-rejection.patch +++ /dev/null @@ -1,258 +0,0 @@ -From 3f0c615a802e196f5e14a9819a81e7c74fb6b988 Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?Marco=20Trevisan=20=28Trevi=C3=B1o=29?= -Date: Mon, 21 Feb 2022 17:17:10 +0100 -Subject: [PATCH 1/2] context: Only warn about unhandled promises when the job - queue is flushed - -A promise rejection may be reported as not handled even though it's -going to be handled by a later added promise. In such case we were -correctly be informed about this via -unregister_unhandled_promise_rejection(), but given that since commit -4446ee7f we promptly warn about unhandled promise rejections our -unhandled rejections stack trace list was cleared earlier than we'd got -an unregistration event. - -To avoid this, let's just wait for the job queue to be fully processed, -so that we won't accidentally clear the unhandled rejections list, until -those have been fully processed. - -By doing this we are both avoiding misbehaving on the said case, and we -don't regress by keeping the exit-warns handled by #417 still valid. - -Added tests to cover both a normal rejection case and the one that was -previously leading to a crash (assertion error). - -Fixes: #466 ---- - gi/closure.cpp | 4 +- - gi/function.cpp | 6 +- - gjs/context.cpp | 6 +- - installed-tests/js/meson.build | 1 + - installed-tests/js/testPromise.js | 106 ++++++++++++++++++++++++++++++ - 5 files changed, 115 insertions(+), 8 deletions(-) - create mode 100644 installed-tests/js/testPromise.js - -diff --git a/gi/closure.cpp b/gi/closure.cpp -index 15b6a5fe7..288550a05 100644 ---- a/gi/closure.cpp -+++ b/gi/closure.cpp -@@ -183,7 +183,9 @@ bool Closure::invoke(JS::HandleObject this_obj, - JS::RootedFunction func(m_cx, m_func); - bool ok = JS::Call(m_cx, this_obj, func, args, retval); - GjsContextPrivate* gjs = GjsContextPrivate::from_cx(m_cx); -- gjs->warn_about_unhandled_promise_rejections(); -+ -+ if (gjs->should_exit(nullptr)) -+ gjs->warn_about_unhandled_promise_rejections(); - if (!ok) { - /* Exception thrown... */ - gjs_debug_closure( -diff --git a/gi/function.cpp b/gi/function.cpp -index f39dc1727..716acc8ec 100644 ---- a/gi/function.cpp -+++ b/gi/function.cpp -@@ -379,11 +379,11 @@ void GjsCallbackTrampoline::callback_closure(GIArgument** args, void* result) { - // main loop, or maybe not, but there's no way to tell, so we have - // to exit here instead of propagating the exception back to the - // original calling JS code. -- gjs->warn_about_unhandled_promise_rejections(); -- - uint8_t code; -- if (gjs->should_exit(&code)) -+ if (gjs->should_exit(&code)) { -+ gjs->warn_about_unhandled_promise_rejections(); - exit(code); -+ } - - // Some other uncatchable exception, e.g. out of memory - JSFunction* fn = callable(); -diff --git a/gjs/context.cpp b/gjs/context.cpp -index 7a6eba6e7..0ba6b250a 100644 ---- a/gjs/context.cpp -+++ b/gjs/context.cpp -@@ -1080,10 +1080,7 @@ bool GjsContextPrivate::run_jobs_fallible(GCancellable* cancellable) { - JSAutoRealm ar(m_cx, job); - gjs_debug(GJS_DEBUG_CONTEXT, "handling job %s", - gjs_debug_object(job).c_str()); -- bool ok = -- JS::Call(m_cx, JS::UndefinedHandleValue, job, args, &rval); -- warn_about_unhandled_promise_rejections(); -- if (!ok) { -+ if (!JS::Call(m_cx, JS::UndefinedHandleValue, job, args, &rval)) { - /* Uncatchable exception - return false so that - * System.exit() works in the interactive shell and when - * exiting the interpreter. */ -@@ -1104,6 +1101,7 @@ bool GjsContextPrivate::run_jobs_fallible(GCancellable* cancellable) { - - m_draining_job_queue = false; - m_job_queue.clear(); -+ warn_about_unhandled_promise_rejections(); - JS::JobQueueIsEmpty(m_cx); - return retval; - } -diff --git a/installed-tests/js/meson.build b/installed-tests/js/meson.build -index f531fd356..567e5cc7c 100644 ---- a/installed-tests/js/meson.build -+++ b/installed-tests/js/meson.build -@@ -137,6 +137,7 @@ jasmine_tests = [ - 'Package', - 'ParamSpec', - 'Print', -+ 'Promise', - 'Regress', - 'Signals', - 'System', -diff --git a/installed-tests/js/testPromise.js b/installed-tests/js/testPromise.js -new file mode 100644 -index 000000000..df302bac2 ---- /dev/null -+++ b/installed-tests/js/testPromise.js -@@ -0,0 +1,106 @@ -+// -*- mode: js; indent-tabs-mode: nil -*- -+// SPDX-License-Identifier: MIT OR LGPL-2.0-or-later -+// SPDX-FileContributor: Authored by: Marco Trevisan -+// SPDX-FileCopyrightText: 2022 Canonical, Ltd. -+ -+const {GLib} = imports.gi; -+ -+class SubPromise extends Promise { -+ constructor(executor) { -+ super((resolve, reject) => { -+ executor(resolve, reject); -+ }); -+ } -+} -+ -+const PromiseResult = { -+ RESOLVED: 0, -+ FAILED: 1, -+}; -+ -+describe('Promise', function () { -+ let loop; -+ -+ beforeEach(function () { -+ loop = GLib.MainLoop.new(null, false); -+ }); -+ -+ function executePromise(promise) { -+ const promiseResult = {}; -+ -+ promise.then(value => { -+ promiseResult.result = PromiseResult.RESOLVED; -+ promiseResult.value = value; -+ }).catch(e => { -+ promiseResult.result = PromiseResult.FAILED; -+ promiseResult.error = e; -+ }); -+ -+ while (promiseResult.result === undefined) -+ loop.get_context().iteration(true); -+ -+ return promiseResult; -+ } -+ -+ it('waits for all promises before handling unhandled, when handled', function () { -+ let error; -+ let resolved; -+ -+ const promise = async () => { -+ await new SubPromise(resolve => resolve('success')); -+ const rejecting = new SubPromise((_resolve, reject) => reject('got error')); -+ try { -+ await rejecting; -+ } catch (e) { -+ error = e; -+ } finally { -+ resolved = true; -+ } -+ -+ expect(resolved).toBeTrue(); -+ expect(error).toBe('got error'); -+ -+ return 'parent-returned'; -+ }; -+ -+ expect(executePromise(promise())).toEqual({ -+ result: PromiseResult.RESOLVED, -+ value: 'parent-returned', -+ }); -+ }); -+ -+ it('waits for all promises before handling unhandled, when unhandled', function () { -+ const thenHandler = jasmine.createSpy('thenHandler'); -+ -+ const promise = async () => { -+ await new Promise(resolve => resolve('success')); -+ await new Promise((_resolve, reject) => reject(new Error('got error'))); -+ return 'parent-returned'; -+ }; -+ -+ promise().then(thenHandler).catch(); -+ expect(thenHandler).not.toHaveBeenCalled(); -+ -+ GLib.idle_add(GLib.PRIORITY_DEFAULT_IDLE, () => loop.quit()); -+ GLib.test_expect_message('Gjs', GLib.LogLevelFlags.LEVEL_WARNING, -+ 'Unhandled promise rejection.*'); -+ loop.run(); -+ GLib.test_assert_expected_messages_internal('Gjs', 'testPromise.js', 0, -+ 'warnsIfRejected'); -+ }); -+ -+ it('do not lead to high-priority IDLE starvation', function () { -+ const promise = new Promise(resolve => { -+ const id = GLib.idle_add(GLib.PRIORITY_HIGH, () => { -+ resolve(); -+ return GLib.SOURCE_REMOVE; -+ }); -+ GLib.Source.set_name_by_id(id, `Test Idle source ${id}`); -+ }); -+ -+ expect(executePromise(promise)).toEqual({ -+ result: PromiseResult.RESOLVED, -+ value: undefined, -+ }); -+ }); -+}); --- -GitLab - - -From 865d2ae27b853848157215cc60e4888575f13200 Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?Marco=20Trevisan=20=28Trevi=C3=B1o=29?= -Date: Tue, 22 Feb 2022 04:18:40 +0100 -Subject: [PATCH 2/2] context: Only show a critical error if unregistering an - unknown promise - -In case a promise handled is removed too early or never added we may -have a bug, but not enough critical to crash. ---- - gjs/context.cpp | 12 ++++++++---- - 1 file changed, 8 insertions(+), 4 deletions(-) - -diff --git a/gjs/context.cpp b/gjs/context.cpp -index 0ba6b250a..12eb0921c 100644 ---- a/gjs/context.cpp -+++ b/gjs/context.cpp -@@ -1150,10 +1150,14 @@ void GjsContextPrivate::register_unhandled_promise_rejection( - } - - void GjsContextPrivate::unregister_unhandled_promise_rejection(uint64_t id) { -- // Return value unused in G_DISABLE_ASSERT case -- [[maybe_unused]] size_t erased = m_unhandled_rejection_stacks.erase(id); -- g_assert(((void)"Handler attached to rejected promise that wasn't " -- "previously marked as unhandled", erased == 1)); -+ size_t erased = m_unhandled_rejection_stacks.erase(id); -+ if (erased != 1) { -+ g_critical("Promise %" G_GUINT64_FORMAT -+ " Handler attached to rejected promise that wasn't " -+ "previously marked as unhandled or that we wrongly reported " -+ "as unhandled", -+ id); -+ } - } - - void GjsContextPrivate::async_closure_enqueue_for_gc(Gjs::Closure* trampoline) { --- -GitLab - diff --git a/gjs.spec b/gjs.spec index 823e245..2b7ca2f 100644 --- a/gjs.spec +++ b/gjs.spec @@ -3,8 +3,8 @@ %global mozjs91_version 91.7.0 Name: gjs -Version: 1.71.1 -Release: 5%{?dist} +Version: 1.71.90 +Release: 1%{?dist} Summary: Javascript Bindings for GNOME # The following files contain code from Mozilla which @@ -14,12 +14,6 @@ Summary: Javascript Bindings for GNOME License: MIT and (MPLv1.1 or GPLv2+ or LGPLv2+) URL: https://wiki.gnome.org/Projects/Gjs Source0: https://download.gnome.org/sources/%{name}/1.71/%{name}-%{version}.tar.xz -# https://gitlab.gnome.org/GNOME/gjs/-/issues/461 -Patch0: gjs-1.71.1-cairo-textextents-test.patch -# https://gitlab.gnome.org/GNOME/gjs/-/issues/462 -Patch1: gjs-1.71.1-bigint-32bit-test.patch -# https://gitlab.gnome.org/GNOME/gjs/-/merge_requests/729 -Patch2: gjs-1.71.1-promise-rejection.patch BuildRequires: gcc-c++ BuildRequires: meson @@ -103,6 +97,9 @@ sed -i -e "/'Gtk4'/d" installed-tests/js/meson.build %{_datadir}/installed-tests/ %changelog +* Tue Mar 15 2022 David King - 1.71.90-1 +- Update to 1.71.90 + * Tue Mar 08 2022 Frantisek Zatloukal - 1.71.1-5 - Rebuild against mozjs91-91.7.0-1 diff --git a/sources b/sources index 1e867af..a7055b5 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (gjs-1.71.1.tar.xz) = 09a8dc0894ec8f4334553175e70fd98d51822364fdde881d6d9e51912f3258493d9019b2ea808e52e0f8d9ba9fdcd94e1cde8d965986521dcd650549ea835b7b +SHA512 (gjs-1.71.90.tar.xz) = 2d835469569dd91b641353cfba4173007bf6028650069107fe64e9757af09a4d53107f7e63d1a74e0c91cdb0dc02d4cde13e667e7c3e839efc44e64815f161bd