mirror of
1
Fork 0
forgejo/models/db
zeripath 716fcfcf72
Make every not exist error unwrappable to a fs.ErrNotExist (#20891)
A lot of our code is repeatedly testing if individual errors are
specific types of Not Exist errors. This is repetitative and unnecesary.
`Unwrap() error` provides a common way of labelling an error as a
NotExist error and we can/should use this.

This PR has chosen to use the common `io/fs` errors e.g.
`fs.ErrNotExist` for our errors. This is in some ways not completely
correct as these are not filesystem errors but it seems like a
reasonable thing to do and would allow us to simplify a lot of our code
to `errors.Is(err, fs.ErrNotExist)` instead of
`package.IsErr...NotExist(err)`

I am open to suggestions to use a different base error - perhaps
`models/db.ErrNotExist` if that would be felt to be better.


Signed-off-by: Andrew Thornton <art27@cantab.net>
Co-authored-by: delvh <dev.lh@web.de>
2022-10-18 07:50:37 +02:00
..
install Improve install code to avoid low-level mistakes. (#17779) 2021-12-01 15:50:01 +08:00
paginator Use a struct as test options (#19393) 2022-04-14 21:58:21 +08:00
common.go Modify milestone search keywords to be case insensitive again (#20513) 2022-07-28 18:58:04 +02:00
consistency.go Move issues related files into models/issues (#19931) 2022-06-13 17:37:59 +08:00
context.go Fix various typos (#20338) 2022-07-12 23:32:37 +02:00
convert.go Refactor auth package (#17962) 2022-01-02 21:12:35 +08:00
engine.go Make every not exist error unwrappable to a fs.ErrNotExist (#20891) 2022-10-18 07:50:37 +02:00
engine_test.go test: use `T.TempDir` to create temporary test directory (#21043) 2022-09-04 16:14:53 +01:00
error.go Make every not exist error unwrappable to a fs.ErrNotExist (#20891) 2022-10-18 07:50:37 +02:00
index.go Refactor GetNextResourceIndex to make it work properly with transaction (#21469) 2022-10-16 18:44:16 +08:00
index_test.go Refactor GetNextResourceIndex to make it work properly with transaction (#21469) 2022-10-16 18:44:16 +08:00
iterate.go Add migrate repo archiver and packages storage support on command line (#20757) 2022-08-16 12:05:15 +08:00
list_options.go Add more linters to improve code readability (#19989) 2022-06-20 12:02:49 +02:00
log.go Allow manager logging to set SQL (#20064) 2022-06-24 12:49:47 +02:00
main_test.go Move tests as seperate sub packages to reduce duplicated file names (#19951) 2022-06-15 09:02:00 +02:00
name.go Make every not exist error unwrappable to a fs.ErrNotExist (#20891) 2022-10-18 07:50:37 +02:00
search.go Move user related model into models/user (#17781) 2021-11-24 17:49:20 +08:00
sequence.go Move db related basic functions to models/db (#17075) 2021-09-19 19:49:59 +08:00
sql_postgres_with_schema.go Add more linters to improve code readability (#19989) 2022-06-20 12:02:49 +02:00