Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
45d1dd28
Commit
45d1dd28
authored
Sep 12, 2018
by
DJ Mountney
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Port of force-post-migration-dir-schema-load to EE
parent
3afd4ab9
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
85 additions
and
20 deletions
+85
-20
changelogs/unreleased/force-post-migration-dir-schema-load.yml
...elogs/unreleased/force-post-migration-dir-schema-load.yml
+5
-0
config/initializers/0_post_deployment_migrations.rb
config/initializers/0_post_deployment_migrations.rb
+1
-20
ee/lib/ee/gitlab/database.rb
ee/lib/ee/gitlab/database.rb
+24
-0
lib/gitlab/database.rb
lib/gitlab/database.rb
+20
-0
lib/tasks/gitlab/db.rake
lib/tasks/gitlab/db.rake
+2
-0
spec/tasks/gitlab/db_rake_spec.rb
spec/tasks/gitlab/db_rake_spec.rb
+33
-0
No files found.
changelogs/unreleased/force-post-migration-dir-schema-load.yml
0 → 100644
View file @
45d1dd28
---
title
:
Ensure the schema is loaded with post_migrations included
merge_request
:
author
:
type
:
changed
config/initializers/0_post_deployment_migrations.rb
View file @
45d1dd28
# Post deployment migrations are included by default. This file must be loaded
# Post deployment migrations are included by default. This file must be loaded
# before other initializers as Rails may otherwise memoize a list of migrations
# before other initializers as Rails may otherwise memoize a list of migrations
# excluding the post deployment migrations.
# excluding the post deployment migrations.
unless
ENV
[
'SKIP_POST_DEPLOYMENT_MIGRATIONS'
]
Gitlab
::
Database
.
add_post_migrate_path_to_rails
Rails
.
application
.
config
.
paths
[
'db'
].
each
do
|
db_path
|
path
=
Rails
.
root
.
join
(
db_path
,
'post_migrate'
).
to_s
Rails
.
application
.
config
.
paths
[
'db/migrate'
]
<<
path
# Rails memoizes migrations at certain points where it won't read the above
# path just yet. As such we must also update the following list of paths.
ActiveRecord
::
Migrator
.
migrations_paths
<<
path
end
end
migrate_paths
=
Rails
.
application
.
config
.
paths
[
'db/migrate'
].
to_a
migrate_paths
.
each
do
|
migrate_path
|
absolute_migrate_path
=
Pathname
.
new
(
migrate_path
).
realpath
(
Rails
.
root
)
ee_migrate_path
=
Rails
.
root
.
join
(
'ee/'
,
absolute_migrate_path
.
relative_path_from
(
Rails
.
root
))
Rails
.
application
.
config
.
paths
[
'db/migrate'
]
<<
ee_migrate_path
.
to_s
ActiveRecord
::
Migrator
.
migrations_paths
<<
ee_migrate_path
.
to_s
end
ee/lib/ee/gitlab/database.rb
0 → 100644
View file @
45d1dd28
module
EE
module
Gitlab
module
Database
extend
::
Gitlab
::
Utils
::
Override
override
:add_post_migrate_path_to_rails
def
add_post_migrate_path_to_rails
(
force:
false
)
super
migrate_paths
=
Rails
.
application
.
config
.
paths
[
'db/migrate'
].
to_a
migrate_paths
.
each
do
|
migrate_path
|
relative_migrate_path
=
Pathname
.
new
(
migrate_path
).
realpath
(
Rails
.
root
).
relative_path_from
(
Rails
.
root
)
ee_migrate_path
=
Rails
.
root
.
join
(
'ee/'
,
relative_migrate_path
)
next
if
relative_migrate_path
.
to_s
.
start_with?
(
'ee/'
)
||
Rails
.
application
.
config
.
paths
[
'db/migrate'
].
include?
(
ee_migrate_path
.
to_s
)
Rails
.
application
.
config
.
paths
[
'db/migrate'
]
<<
ee_migrate_path
.
to_s
ActiveRecord
::
Migrator
.
migrations_paths
<<
ee_migrate_path
.
to_s
end
end
end
end
end
lib/gitlab/database.rb
View file @
45d1dd28
...
@@ -9,6 +9,10 @@ module Gitlab
...
@@ -9,6 +9,10 @@ module Gitlab
# https://dev.mysql.com/doc/refman/5.7/en/datetime.html
# https://dev.mysql.com/doc/refman/5.7/en/datetime.html
MAX_TIMESTAMP_VALUE
=
Time
.
at
((
1
<<
31
)
-
1
).
freeze
MAX_TIMESTAMP_VALUE
=
Time
.
at
((
1
<<
31
)
-
1
).
freeze
class
<<
self
prepend
EE
::
Gitlab
::
Database
end
def
self
.
config
def
self
.
config
ActiveRecord
::
Base
.
configurations
[
Rails
.
env
]
ActiveRecord
::
Base
.
configurations
[
Rails
.
env
]
end
end
...
@@ -261,5 +265,21 @@ module Gitlab
...
@@ -261,5 +265,21 @@ module Gitlab
end
end
private_class_method
:database_version
private_class_method
:database_version
def
self
.
add_post_migrate_path_to_rails
(
force:
false
)
return
if
ENV
[
'SKIP_POST_DEPLOYMENT_MIGRATIONS'
]
&&
!
force
Rails
.
application
.
config
.
paths
[
'db'
].
each
do
|
db_path
|
path
=
Rails
.
root
.
join
(
db_path
,
'post_migrate'
).
to_s
unless
Rails
.
application
.
config
.
paths
[
'db/migrate'
].
include?
path
Rails
.
application
.
config
.
paths
[
'db/migrate'
]
<<
path
# Rails memoizes migrations at certain points where it won't read the above
# path just yet. As such we must also update the following list of paths.
ActiveRecord
::
Migrator
.
migrations_paths
<<
path
end
end
end
end
end
end
end
lib/tasks/gitlab/db.rake
View file @
45d1dd28
...
@@ -51,6 +51,8 @@ namespace :gitlab do
...
@@ -51,6 +51,8 @@ namespace :gitlab do
if
ActiveRecord
::
Base
.
connection
.
tables
.
count
>
1
if
ActiveRecord
::
Base
.
connection
.
tables
.
count
>
1
Rake
::
Task
[
'db:migrate'
].
invoke
Rake
::
Task
[
'db:migrate'
].
invoke
else
else
# Add post-migrate paths to ensure we mark all migrations as up
Gitlab
::
Database
.
add_post_migrate_path_to_rails
(
force:
true
)
Rake
::
Task
[
'db:schema:load'
].
invoke
Rake
::
Task
[
'db:schema:load'
].
invoke
Rake
::
Task
[
'db:seed_fu'
].
invoke
Rake
::
Task
[
'db:seed_fu'
].
invoke
end
end
...
...
spec/tasks/gitlab/db_rake_spec.rb
View file @
45d1dd28
...
@@ -61,6 +61,39 @@ describe 'gitlab:db namespace rake task' do
...
@@ -61,6 +61,39 @@ describe 'gitlab:db namespace rake task' do
expect
(
Rake
::
Task
[
'db:migrate'
]).
not_to
receive
(
:invoke
)
expect
(
Rake
::
Task
[
'db:migrate'
]).
not_to
receive
(
:invoke
)
expect
{
run_rake_task
(
'gitlab:db:configure'
)
}.
to
raise_error
(
RuntimeError
,
'error'
)
expect
{
run_rake_task
(
'gitlab:db:configure'
)
}.
to
raise_error
(
RuntimeError
,
'error'
)
end
end
context
'SKIP_POST_DEPLOYMENT_MIGRATIONS environment variable set'
do
let
(
:rails_paths
)
{
{
'db'
=>
[
'db'
],
'db/migrate'
=>
[
'db/migrate'
]
}
}
before
do
allow
(
ENV
).
to
receive
(
:[]
).
and_call_original
allow
(
ENV
).
to
receive
(
:[]
).
with
(
'SKIP_POST_DEPLOYMENT_MIGRATIONS'
).
and_return
true
# Our environment has already been loaded, so we need to pretend like post_migrations were not
allow
(
Rails
.
application
.
config
).
to
receive
(
:paths
).
and_return
(
rails_paths
)
allow
(
ActiveRecord
::
Migrator
).
to
receive
(
:migrations_paths
).
and_return
(
rails_paths
[
'db/migrate'
].
dup
)
end
it
'adds post deployment migrations before schema load if the schema is not already loaded'
do
allow
(
ActiveRecord
::
Base
.
connection
).
to
receive
(
:tables
).
and_return
([])
expect
(
Gitlab
::
Database
).
to
receive
(
:add_post_migrate_path_to_rails
).
and_call_original
expect
(
Rake
::
Task
[
'db:schema:load'
]).
to
receive
(
:invoke
)
expect
(
Rake
::
Task
[
'db:seed_fu'
]).
to
receive
(
:invoke
)
expect
(
Rake
::
Task
[
'db:migrate'
]).
not_to
receive
(
:invoke
)
expect
{
run_rake_task
(
'gitlab:db:configure'
)
}.
not_to
raise_error
expect
(
rails_paths
[
'db/migrate'
].
include?
(
File
.
join
(
Rails
.
root
,
'db'
,
'post_migrate'
))).
to
be
(
true
)
end
it
'ignores post deployment migrations when schema has already been loaded'
do
allow
(
ActiveRecord
::
Base
.
connection
).
to
receive
(
:tables
).
and_return
(
%w[table1 table2]
)
expect
(
Rake
::
Task
[
'db:migrate'
]).
to
receive
(
:invoke
)
expect
(
Gitlab
::
Database
).
not_to
receive
(
:add_post_migrate_path_to_rails
)
expect
(
Rake
::
Task
[
'db:schema:load'
]).
not_to
receive
(
:invoke
)
expect
(
Rake
::
Task
[
'db:seed_fu'
]).
not_to
receive
(
:invoke
)
expect
{
run_rake_task
(
'gitlab:db:configure'
)
}.
not_to
raise_error
expect
(
rails_paths
[
'db/migrate'
].
include?
(
File
.
join
(
Rails
.
root
,
'db'
,
'post_migrate'
))).
to
be
(
false
)
end
end
end
end
def
run_rake_task
(
task_name
)
def
run_rake_task
(
task_name
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment