Welcome to mirror list, hosted at ThFree Co, Russian Federation.

pages.rake « gitlab « tasks « lib - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 107e0d08b70bd3e39c4a3cf071bbb3d06db17da0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
require 'logger'

namespace :gitlab do
  namespace :pages do
    desc "GitLab | Pages | Migrate legacy storage to zip format"
    task migrate_legacy_storage: :gitlab_environment do
      logger = Logger.new(STDOUT)
      logger.info('Starting to migrate legacy pages storage to zip deployments')
      projects_migrated = 0
      projects_errored = 0

      ProjectPagesMetadatum.only_on_legacy_storage.each_batch(of: 10) do |batch|
        batch.preload(project: [:namespace, :route, pages_metadatum: :pages_deployment]).each do |metadatum|
          project = metadatum.project

          result = nil
          time = Benchmark.realtime do
            result = ::Pages::MigrateLegacyStorageToDeploymentService.new(project).execute
          end

          if result[:status] == :success
            logger.info("project_id: #{project.id} #{project.pages_path} has been migrated in #{time} seconds")
            projects_migrated += 1
          else
            logger.error("project_id: #{project.id} #{project.pages_path} failed to be migrated in #{time} seconds: #{result[:message]}")
            projects_errored += 1
          end
        rescue => e
          projects_errored += 1
          logger.error("#{e.message} project_id: #{project&.id}")
          Gitlab::ErrorTracking.track_exception(e, project_id: project&.id)
        end

        logger.info("#{projects_migrated} projects are migrated successfully, #{projects_errored} projects failed to be migrated")
      end

      logger.info("A total of #{projects_migrated + projects_errored} projects were processed.")
      logger.info("- The #{projects_migrated} projects migrated successfully")
      logger.info("- The #{projects_errored} projects failed to be migrated")
    end
  end
end