From e528e8680faa03c95fd7a815682ed019c9a403f5 Mon Sep 17 00:00:00 2001 From: Adam Hegyi Date: Tue, 10 Sep 2019 15:39:53 +0200 Subject: [PATCH] Database table for language trends over time - Introduce new DB table for tracking language trend over time. --- .../unreleased/language-trends-over-time.yml | 5 +++ ...ics_language_trend_repository_languages.rb | 35 +++++++++++++++++++ db/schema.rb | 15 ++++++++ 3 files changed, 55 insertions(+) create mode 100644 changelogs/unreleased/language-trends-over-time.yml create mode 100644 db/migrate/20190910125852_create_analytics_language_trend_repository_languages.rb 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 -- GitLab