summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdam Hegyi <ahegyi@gitlab.com>2019-09-10 15:39:53 +0200
committerAdam Hegyi <ahegyi@gitlab.com>2019-09-12 14:05:45 +0200
commite528e8680faa03c95fd7a815682ed019c9a403f5 (patch)
tree61b92b3fd77a4d0cfa0ccbeaf60ac5181e633c9e
parent1928932388f063b064dde9d235b6474121a726c0 (diff)
downloadgitlab-ce-language-trends-over-time.tar.gz
Database table for language trends over timelanguage-trends-over-time
- Introduce new DB table for tracking language trend over time.
-rw-r--r--changelogs/unreleased/language-trends-over-time.yml5
-rw-r--r--db/migrate/20190910125852_create_analytics_language_trend_repository_languages.rb35
-rw-r--r--db/schema.rb15
3 files changed, 55 insertions, 0 deletions
diff --git a/changelogs/unreleased/language-trends-over-time.yml b/changelogs/unreleased/language-trends-over-time.yml
new file mode 100644
index 00000000000..cf6b51098a0
--- /dev/null
+++ b/changelogs/unreleased/language-trends-over-time.yml
@@ -0,0 +1,5 @@
+---
+title: Database table for tracking programming language trends over time
+merge_request: 32883
+author:
+type: added
diff --git a/db/migrate/20190910125852_create_analytics_language_trend_repository_languages.rb b/db/migrate/20190910125852_create_analytics_language_trend_repository_languages.rb
new file mode 100644
index 00000000000..c0a97bff677
--- /dev/null
+++ b/db/migrate/20190910125852_create_analytics_language_trend_repository_languages.rb
@@ -0,0 +1,35 @@
+# frozen_string_literal: true
+
+class CreateAnalyticsLanguageTrendRepositoryLanguages < ActiveRecord::Migration[5.2]
+ DOWNTIME = false
+ INDEX_PREFIX = 'analytics_repository_languages_'
+
+ def change
+ create_table :analytics_language_trend_repository_languages, id: false do |t|
+ t.integer :file_count, null: false, default: 0
+ t.references :programming_language, {
+ null: false,
+ foreign_key: { on_delete: :cascade },
+ index: { name: INDEX_PREFIX + 'on_programming_language_id' }
+ }
+ t.references :project, {
+ null: false,
+ foreign_key: { on_delete: :cascade },
+ index: { name: INDEX_PREFIX + 'on_project_id' }
+ }
+ t.integer :loc, null: false, default: 0
+ t.integer :bytes, null: false, default: 0
+ # Storing percentage (with 2 decimal places), on 2 bytes.
+ # 50.25% => 5025
+ # Max: 100.00% => 10000 (fits smallint: 32767)
+ t.integer :percentage, limit: 2, null: false, default: 0
+ t.date :snapshot_date, null: false
+ end
+
+ add_index :analytics_language_trend_repository_languages, %I[
+ programming_language_id
+ project_id
+ snapshot_date
+ ], name: INDEX_PREFIX + 'unique_index', unique: true
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index 39faf1e651e..0109a545ad2 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -72,6 +72,19 @@ ActiveRecord::Schema.define(version: 2019_09_12_061145) do
t.index ["start_event_label_id"], name: "index_analytics_ca_project_stages_on_start_event_label_id"
end
+ create_table "analytics_language_trend_repository_languages", id: false, force: :cascade do |t|
+ t.integer "file_count", default: 0, null: false
+ t.bigint "programming_language_id", null: false
+ t.bigint "project_id", null: false
+ t.integer "loc", default: 0, null: false
+ t.integer "bytes", default: 0, null: false
+ t.integer "percentage", limit: 2, default: 0, null: false
+ t.date "snapshot_date", null: false
+ t.index ["programming_language_id", "project_id", "snapshot_date"], name: "analytics_repository_languages_unique_index", unique: true
+ t.index ["programming_language_id"], name: "analytics_repository_languages_on_programming_language_id"
+ t.index ["project_id"], name: "analytics_repository_languages_on_project_id"
+ end
+
create_table "appearances", id: :serial, force: :cascade do |t|
t.string "title", null: false
t.text "description", null: false
@@ -3747,6 +3760,8 @@ ActiveRecord::Schema.define(version: 2019_09_12_061145) do
add_foreign_key "analytics_cycle_analytics_project_stages", "labels", column: "end_event_label_id", on_delete: :cascade
add_foreign_key "analytics_cycle_analytics_project_stages", "labels", column: "start_event_label_id", on_delete: :cascade
add_foreign_key "analytics_cycle_analytics_project_stages", "projects", on_delete: :cascade
+ add_foreign_key "analytics_language_trend_repository_languages", "programming_languages", on_delete: :cascade
+ add_foreign_key "analytics_language_trend_repository_languages", "projects", on_delete: :cascade
add_foreign_key "application_settings", "namespaces", column: "custom_project_templates_group_id", on_delete: :nullify
add_foreign_key "application_settings", "projects", column: "file_template_project_id", name: "fk_ec757bd087", on_delete: :nullify
add_foreign_key "application_settings", "projects", column: "instance_administration_project_id", on_delete: :nullify