I took a look; the issue is here:
Here is what happens.
When you remove the last character, get
is called. At this point, _searchTerm
is empty.
However, this._searchTerm || this.q
will treat the empty string as falsy, and the value of q
is displayed instead.
A quick fix could be to check this way:
return this._searchTerm !== undefined ? this._searchTerm : this.q;
Note: the initial value of _searchTerm
is undefined
.
Note: because of computed("q")
, the issue doesn’t happen when you select/delete (probably because the timing is too tight to invalidate the cache?)
I wanted to PR, but..
the core tests (without modification) fail for some reason.
I’m using bin/rspec spec/system/user_activity_bookmarks_spec.rb
.
The log says that either the search is not present or bookmarks are not created.
Do I miss something?
Logs
(base) arkshine@HOME:~/discourse$ bin/rspec spec/system/user_activity_bookmarks_spec.rb
Randomized with seed 38172
unknown OID 931304: failed to recognize type of ‘embeddings’. It will be treated as String.
FFF
Failures:
-
User activity bookmarks can clear the query
Failure/Error: superCapybara::ElementNotFound:
Unable to find field “bookmark-search” that is not disabled~~~~~ END JS LOGS ~~~~~ # ./spec/system/page_objects/pages/user_activity_bookmarks.rb:24:in `fill_in_search' # ./spec/system/page_objects/pages/user_activity_bookmarks.rb:14:in `search_for' # ./spec/system/user_activity_bookmarks_spec.rb:51:in `block (2 levels) in <main>'
-
User activity bookmarks can filter the list of bookmarks
Failure/Error: superCapybara::ElementNotFound:
Unable to find field “bookmark-search” that is not disabled~~~~~ END JS LOGS ~~~~~ # ./spec/system/page_objects/pages/user_activity_bookmarks.rb:24:in `fill_in_search' # ./spec/system/page_objects/pages/user_activity_bookmarks.rb:14:in `search_for' # ./spec/system/user_activity_bookmarks_spec.rb:44:in `block (2 levels) in <main>'
-
User activity bookmarks can filter the list of bookmarks from the URL
Failure/Error: expect(user_activity_bookmarks).to have_topic(bookmark_1.bookmarkable.topic)
expected#<PageObjects::Pages::UserActivityBookmarks:0x00007f51dcb37b00>.has_topic?(#<Topic id: 699, title: "This is a test topic 0", last_posted_at: nil, created_at: "2025-03-19 04:35:...oad_id: nil, slow_mode_seconds: 0, bannered_until: nil, external_id: nil, visibility_reason_id: nil>)
to be truthy, got false~~~~~ END JS LOGS ~~~~~ # ./spec/system/user_activity_bookmarks_spec.rb:40:in `block (2 levels) in <main>'
Finished in 21.7 seconds (files took 3.8 seconds to load)
3 examples, 3 failures
Failed examples:
rspec ./spec/system/user_activity_bookmarks_spec.rb:50 # User activity bookmarks can clear the query
rspec ./spec/system/user_activity_bookmarks_spec.rb:43 # User activity bookmarks can filter the list of bookmarks
rspec ./spec/system/user_activity_bookmarks_spec.rb:36 # User activity bookmarks can filter the list of bookmarks from the URL