You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
memos/store/test
Steven 8770b186e4 fix: add Unicode case-insensitive search for SQLite (#5559)
Add custom memos_unicode_lower() SQLite function to enable proper
case-insensitive text search for non-English languages (Cyrillic,
Greek, CJK, etc.).

Previously, SQLite's LOWER() only worked for ASCII characters due to
modernc.org/sqlite lacking ICU extension. This caused searches for
non-English text to be case-sensitive (e.g., searching 'блины' wouldn't
find 'Блины').

Changes:
- Add store/db/sqlite/functions.go with Unicode case folding function
- Register custom function using golang.org/x/text/cases.Fold()
- Update filter renderer to use custom function for SQLite dialect
- Add test for Unicode case-insensitive search
- Make golang.org/x/text a direct dependency

Fixes #5559
1 month ago
..
README.md
activity_test.go
attachment_filter_test.go
attachment_test.go
containers.go fix: resolve flaky migration tests and add stable upgrade test (#5514) 2 months ago
filter_helpers_test.go
idp_test.go
inbox_test.go
instance_setting_test.go
main_test.go fix: resolve flaky migration tests and add stable upgrade test (#5514) 2 months ago
memo_filter_test.go fix: add Unicode case-insensitive search for SQLite (#5559) 1 month ago
memo_relation_test.go
memo_test.go
migrator_test.go fix: resolve flaky migration tests and add stable upgrade test (#5514) 2 months ago
reaction_test.go
store.go refactor: migrate HOST roles to ADMIN 2 months ago
user_setting_test.go
user_test.go refactor: migrate HOST roles to ADMIN 2 months ago

README.md

Store tests

How to test store with MySQL?

  1. Create a database in your MySQL server.
  2. Run the following command with two environment variables set:
DRIVER=mysql DSN=root@/memos_test go test -v ./test/store/...
  • DRIVER should be set to mysql.
  • DSN should be set to the DSN of your MySQL server.