98 lines
2.5 KiB
Ruby
98 lines
2.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Gitlab
|
|
module Database
|
|
module SchemaValidation
|
|
class TrackInconsistency
|
|
def initialize(inconsistency, project, user)
|
|
@inconsistency = inconsistency
|
|
@project = project
|
|
@user = user
|
|
end
|
|
|
|
def execute
|
|
return unless Gitlab.com?
|
|
return if inconsistency_record.present?
|
|
|
|
result = ::Issues::CreateService.new(container: project, current_user: user, params: params,
|
|
spam_params: nil).execute
|
|
|
|
track_inconsistency(result[:issue]) if result.success?
|
|
end
|
|
|
|
private
|
|
|
|
attr_reader :inconsistency, :project, :user
|
|
|
|
def track_inconsistency(issue)
|
|
schema_inconsistency_model.create(
|
|
issue: issue,
|
|
object_name: inconsistency.object_name,
|
|
table_name: inconsistency.table_name,
|
|
valitador_name: inconsistency.type
|
|
)
|
|
end
|
|
|
|
def params
|
|
{
|
|
title: issue_title,
|
|
description: issue_description,
|
|
issue_type: 'issue',
|
|
labels: %w[database database-inconsistency-report]
|
|
}
|
|
end
|
|
|
|
def issue_title
|
|
"New schema inconsistency: #{inconsistency.object_name}"
|
|
end
|
|
|
|
def issue_description
|
|
<<~MSG
|
|
We have detected a new schema inconsistency.
|
|
|
|
**Table name:** #{inconsistency.table_name}\
|
|
**Object name:** #{inconsistency.object_name}\
|
|
**Validator name:** #{inconsistency.type}\
|
|
**Object type:** #{inconsistency.object_type}\
|
|
**Error message:** #{inconsistency.error_message}
|
|
|
|
|
|
**Structure.sql statement:**
|
|
|
|
```sql
|
|
#{inconsistency.structure_sql_statement}
|
|
```
|
|
|
|
**Database statement:**
|
|
|
|
```sql
|
|
#{inconsistency.database_statement}
|
|
```
|
|
|
|
**Diff:**
|
|
|
|
```diff
|
|
#{inconsistency.diff}
|
|
|
|
```
|
|
|
|
|
|
For more information, please contact the database team.
|
|
MSG
|
|
end
|
|
|
|
def schema_inconsistency_model
|
|
Gitlab::Database::SchemaValidation::SchemaInconsistency
|
|
end
|
|
|
|
def inconsistency_record
|
|
schema_inconsistency_model.find_by(
|
|
object_name: inconsistency.object_name,
|
|
table_name: inconsistency.table_name,
|
|
valitador_name: inconsistency.type
|
|
)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|