diff --git a/changelogs/unreleased/language-trends-over-time.yml b/changelogs/unreleased/language-trends-over-time.yml new file mode 100644 index 0000000000000000000000000000000000000000..f7a5cb12fa11e718f0c003ae1d6c32b13dc4a6df --- /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: 16491 +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 0000000000000000000000000000000000000000..07da4c20d554553f55ab00228af8ab0f1b11d641 --- /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: false + } + 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 b43779f4126c76d69c2fadc8c28b331f48ebbb20..bb83668f0c8352737e10bdf6ac0be91d2eb62f26 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -81,6 +81,18 @@ 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 ["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 @@ -3762,6 +3774,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 diff --git a/ee/app/models/analytics/language_trend.rb b/ee/app/models/analytics/language_trend.rb new file mode 100644 index 0000000000000000000000000000000000000000..a69f6afa3ad7a67ebc341fa9047c6c5a6d0f0cc2 --- /dev/null +++ b/ee/app/models/analytics/language_trend.rb @@ -0,0 +1,7 @@ +# frozen_string_literal: true + +module Analytics::LanguageTrend + def self.table_name_prefix + 'analytics_language_trend_' + end +end diff --git a/ee/app/models/analytics/language_trend/repository_language.rb b/ee/app/models/analytics/language_trend/repository_language.rb new file mode 100644 index 0000000000000000000000000000000000000000..deb8f5d78a4a57e855315c3bf860e6bd7b4c7299 --- /dev/null +++ b/ee/app/models/analytics/language_trend/repository_language.rb @@ -0,0 +1,6 @@ +# frozen_string_literal: true + +class Analytics::LanguageTrend::RepositoryLanguage < ApplicationRecord + belongs_to :programming_language + belongs_to :project +end diff --git a/ee/spec/models/analytics/language_trend/repository_language_spec.rb b/ee/spec/models/analytics/language_trend/repository_language_spec.rb new file mode 100644 index 0000000000000000000000000000000000000000..ea048f6a8c5f360a0cf9a39cfa1665a35302926e --- /dev/null +++ b/ee/spec/models/analytics/language_trend/repository_language_spec.rb @@ -0,0 +1,10 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe Analytics::LanguageTrend::RepositoryLanguage do + describe 'associations' do + it { is_expected.to belong_to(:programming_language) } + it { is_expected.to belong_to(:project) } + end +end