Changelog
This class represent a changelog directory. The directory name is the version of the changelog.
Source code in pum/changelog.py
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 | |
__init__
apply
apply(connection: Connection, parameters: dict | None = None, commit: bool = True, schema_migrations: SchemaMigrations | None = None, beta_testing: bool = False, feedback: Feedback | None = None) -> list[Path]
Apply a changelog This will execute all the files in the changelog directory. The changelog directory is the one that contains the delta files.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
connection
|
Connection
|
Connection The connection to the database |
required |
parameters
|
dict | None
|
dict The parameters to pass to the SQL files |
None
|
commit
|
bool
|
bool If true, the transaction is committed. The default is true. |
True
|
schema_migrations
|
SchemaMigrations | None
|
SchemaMigrations | None The SchemaMigrations instance to use to record the applied changelog. If None, the changelog will not be recorded. |
None
|
beta_testing
|
bool
|
bool If true, the changelog will be recorded as a beta testing version. |
False
|
feedback
|
Feedback | None
|
Feedback | None Optional feedback object for progress reporting. |
None
|
Returns:
| Type | Description |
|---|---|
list[Path]
|
list[Path] The list of changelogs that were executed |
Source code in pum/changelog.py
files
Get the ordered list of SQL files in the changelog directory. This is not recursive, it only returns the files in the given changelog directory.
Returns:
| Type | Description |
|---|---|
list[Path]
|
list[Path]: A list of paths to the changelog files. |
Source code in pum/changelog.py
is_applied
Check if the changelog has been applied.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
connection
|
Connection
|
The database connection to use. |
required |
Returns: bool: True if the changelog has been applied, False otherwise.
Source code in pum/changelog.py
validate
Validate the changelog directory. This is done by checking if the directory exists and if it contains at least one SQL file.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
parameters
|
dict | None
|
The parameters to pass to the SQL files. |
None
|
Raises:
| Type | Description |
|---|---|
PumInvalidChangelog
|
If the changelog directory does not exist or does not contain any SQL files. |