J. King
ed22090e49
Work around various SQLite-related problems
- WAL mode was not getting set properly
- Queries using the PDO driver could fail because PDO sucks
6 years ago
J. King
5efef2c2d0
Console command to refresh all feeds once; fixes #147
6 years ago
J. King
44366f48bf
Remove arbitrary search term limits; fixes #150
6 years ago
J. King
21fdd66d37
Work around limit to SQL parameter placeholders for IN() clauses
Improves #150
LIKE-based matches also need to be similarly conservative
6 years ago
J. King
837f3c6dd6
Simplify SQL type handling
This is done in anticipation of dealing with SQL types in
places other than statements
6 years ago
J. King
3b8461b1ca
Add searching to TTRSS handler
6 years ago
J. King
85307bc90a
Add parser for TTRSS search strings
6 years ago
J. King
95de375e0b
Handle folder and label exclusion
Consequently the way label data are retrieved was completely overhauled
6 years ago
J. King
677e33e518
Add text search exclusions
6 years ago
J. King
0dc82f64d5
Allow ranges in exclusion contexts
6 years ago
J. King
18d52ea402
Make exclusion contexts return their parent on change
6 years ago
J. King
b950ac066f
Restrict options in not-context and hopefully make it easier to use
6 years ago
J. King
14c02d56ac
Implement new context options other than not().
Context handling has also been re-organized to simplify later
implementation of the not() option
6 years ago
J. King
f4a74eec5d
Add all the other context options allowed by the TTRSS search syntax
6 years ago
J. King
2df7c25b66
Add ability to search note text
6 years ago
J. King
bc3182a961
Basic substring searching
6 years ago
J. King
ace94e3ef8
Fix context, and context tests
6 years ago
J. King
500851f161
Style fixes
6 years ago
J. King
8ea1df920a
Unify SQL timeouts
- Exec and lock timeouts now apply to MySQL
- Lock timeout now applies to PostgreSQL
- SQLite now uses a generic lock timeout setting which applies to all
6 years ago
J. King
5335d331f7
Fix configuration exporting
6 years ago
J. King
5cd84c4ab4
Validate configuration parameters on import, and other changes
- Each parameter is checked for type and normalized
- Interval strings are converted to DateInterval objects
- Timeouts can be specified as interval strings
- Most intervals can be null to signify infinity
- Driver classes are checked that they implement the correct interface
- Short driver names may be used, and are used by default
- Helpful errors messages are printed in case of erroneous configuration
Exporting is currently broken; this will be fixed in an upcoming commit
6 years ago
J. King
b0643de21c
Add handling of DateInterval objects to ValueInfo
6 years ago
J. King
4670dfc849
Handle connection errors
6 years ago
J. King
e92bda5373
Various changes:
- Fix handling of binary data and long strings
- Simplify handling of socket connections
- Fix coverage
6 years ago
J. King
f3b0c791f8
Fix remaining tests
6 years ago
J. King
5d61ab0a57
Fixes for MySQL native interface
Three test failures remain, but these are minor and will be resolved
soon. Handling of binary data is also broken, but given that this works
fine with the PDO driver, there is presumably some correct method.
6 years ago
J. King
e501fbdc87
Remove the DatabaseInformation class in tests and use traits instead
6 years ago
J. King
81acba90dc
Use strict equality when comparing strings
6 years ago
J. King
c4a41255b0
Experimental native MySQL driver
No testing has been performed yet, but changes are extensive enough to
warrant a commit. Of particular note:
- SQL states are enumerated in a separate trait to reduce duplication
- PDOStatement is now an abstract class to avoid duplication of
engine-specific error handling
- Error handling has been cleaned up somewhat
6 years ago
J. King
206cca35a9
Test tweaks
6 years ago
J. King
f0d30c2eee
Make munging of queries a generic feature
6 years ago
J. King
24df564045
Mostly successful MySQL database function tests
Two failures remain, at least one requiring query munging.
6 years ago
J. King
4ef36643a4
Proof-of-concept PDO MySQL driver
- Configuration options were added
- Non-transactional locking was added to the savepoint handlers
- Tests were adjusted for MySQL's reserved words
6 years ago
J. King
29e7c1f154
Fix coverage
6 years ago
J. King
2bebdd44cf
Implementation of native PostgreSQL interface
Changes to the Database class were required to avoid outputting booleans
6 years ago
J. King
b52dadf345
Make existing PostgreSQL tests explicitly PDO tests
6 years ago
J. King
28f803dd28
Handle PostgreSQL connection errors
6 years ago
J. King
73729a6be8
Simplify database cleanup between tests
6 years ago
J. King
8dbf237626
Group PostgreSQL tests as slow
6 years ago
J. King
913cf71620
Fix incorrect annotations
6 years ago
J. King
f6966659a9
Use smarter coverage executer; properly suppress stderr during CLI tests
6 years ago
J. King
d9629be662
Use smarter coverage executer; properly suppress stderr during CLI tests
6 years ago
J. King
0513b606c2
Merge master
6 years ago
J. King
b9272ea2eb
Fix test failures in PHP 7.1
6 years ago
J. King
f7b9a2a6cf
Fixes for PHPUnit 7
6 years ago
J. King
089f666de6
Fix PDO insert ID errors in PHP 7.1
6 years ago
J. King
cf896121b2
Style fixes
6 years ago
J. King
f2245861e3
Restore complete Database coverage
Also suppress PostgreSQL database function tests from normal coverage,
and add a "coverage:full" task to run them if needed.
6 years ago
J. King
51755a2ce6
Retire article field groups
6 years ago
J. King
0129965bbd
Cover some missed code
6 years ago