The Problem (as stated in https://discuss.folio.org/t/reference-data-and-upgrades/2858)
...
These kinds of issues would very likely also arise if an operator specified loadSample=true
in an upgrade, but that is currently untested, and seems like an unlikely use case, at least for production.
Upgrade Desired Behaviors
- The upgrade process should leave the system in a usable state unless a truly fatal error is detected.
- Rigorous error handling in upgrade scripts to ensure trivial errors do not derail process
- When fatal errors occur, the output should clearly indicate where the error occurred.
- The upgrade process should produce a log output of changes made.
- The upgrade process should be able to run in a simulated mode to facilitate planning.
- The upgrade process should account for the presence of Overlay Data and preserve it entirely.
Proposal
- Eliminate Reference Data as a category.
- Create a new category called "System Data" which holds all schema data and records currently loaded by specifying
loadReference=true
.- Make this category immutable towards the system operator/users.
...
Name | Definition/notes | Overwritten on upgrade | Immutable (towards system operator) | Example of data stored |
---|---|---|---|---|
System Data | Data necessary for operation of the system. These should be values that are immutable toward the user or system operator. Example: sane defaults for field labels. Note: at present, these sort of default values for certain modules are only loaded when you specify LoadReferenceData=true on module initialization. This proposes we move those into an immutable category. | YES | YES | schema_book{
} |
Overlay Data | Data that may be used to supersede System Data when a user or system operator wants to change something immutable Example: a default field label. Can be used to override any System Data, as well as introducing new values. | NO | NO | schema_book{
} |
Sample Data/User Data | Data that can be used to demo the system or is useful for providing examples to users. Data entered by users specific to an institution. This data is not necessary for the operation of the system. Example: a user record for a fake (or real) patron. This layer also holds sample data, since it's essentially real data for a fictional tenant. | NO To load example data (like diku), introduce another switch (LoadExampleData=true) | NO | book: uuid: asdf034 title: 1984 authors: George Orwell publisher: Secker & Warburg release date: June 8, 1949 blurb: Nineteen Eighty-Four: A Novel, often published as 1984, is a dystopian novel by English novelist George Orwell. It was published on 8 June 1949 by Secker & Warburg as Orwell's ninth and final book completed in his lifetime. |
--- Result --- | schema_book{
} book: uuid: asdf034 title: 1984 authors: George Orwell publisher: Secker & Warburg release date: June 8, 1949 blurb: Nineteen Eighty-Four: A Novel, often published as 1984, is a dystopian novel by English novelist George Orwell. It was published on 8 June 1949 by Secker & Warburg as Orwell's ninth and final book completed in his lifetime. |
Upgrade Desired Behaviors
...
- Rigorous error handling in upgrade scripts to ensure trivial errors do not derail process
- When fatal errors occur, the output should clearly indicate where the error occurred.
...
. |