This is an automated email from the ASF dual-hosted git repository.

abeizn pushed a commit to branch release-v0.16
in repository https://gitbox.apache.org/repos/asf/incubator-devlake.git


The following commit(s) were added to refs/heads/release-v0.16 by this push:
     new 54985c8c4 fix: sonarqube modify character set (#4685)
54985c8c4 is described below

commit 54985c8c411d90fbf43fd68875babd1de7cf6c71
Author: abeizn <[email protected]>
AuthorDate: Thu Mar 16 17:03:03 2023 +0800

    fix: sonarqube modify character set (#4685)
---
 ..._init_tables.go => 20230227_add_init_tables.go} |  0
 .../20230316_modify_character_set.go               | 90 ++++++++++++++++++++++
 .../sonarqube/models/migrationscripts/register.go  |  1 +
 3 files changed, 91 insertions(+)

diff --git 
a/backend/plugins/sonarqube/models/migrationscripts/20230111_add_init_tables.go 
b/backend/plugins/sonarqube/models/migrationscripts/20230227_add_init_tables.go
similarity index 100%
rename from 
backend/plugins/sonarqube/models/migrationscripts/20230111_add_init_tables.go
rename to 
backend/plugins/sonarqube/models/migrationscripts/20230227_add_init_tables.go
diff --git 
a/backend/plugins/sonarqube/models/migrationscripts/20230316_modify_character_set.go
 
b/backend/plugins/sonarqube/models/migrationscripts/20230316_modify_character_set.go
new file mode 100644
index 000000000..fa648e838
--- /dev/null
+++ 
b/backend/plugins/sonarqube/models/migrationscripts/20230316_modify_character_set.go
@@ -0,0 +1,90 @@
+/*
+Licensed to the Apache Software Foundation (ASF) under one or more
+contributor license agreements.  See the NOTICE file distributed with
+this work for additional information regarding copyright ownership.
+The ASF licenses this file to You under the Apache License, Version 2.0
+(the "License"); you may not use this file except in compliance with
+the License.  You may obtain a copy of the License at
+
+    http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+*/
+
+package migrationscripts
+
+import (
+       "net/url"
+
+       "github.com/apache/incubator-devlake/core/context"
+       "github.com/apache/incubator-devlake/core/errors"
+)
+
+type modifyCharacterSet struct{}
+
+func (*modifyCharacterSet) Up(basicRes context.BasicRes) errors.Error {
+       dbUrl := basicRes.GetConfig("DB_URL")
+       if dbUrl == "" {
+               return errors.BadInput.New("DB_URL is required")
+       }
+       u, err1 := url.Parse(dbUrl)
+       if err1 != nil {
+               return errors.Convert(err1)
+       }
+       if u.Scheme == "mysql" {
+               err := basicRes.GetDal().Exec(`ALTER TABLE 
_tool_sonarqube_projects CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE 
_tool_sonarqube_issues CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE 
_tool_sonarqube_issue_code_blocks CONVERT TO CHARACTER SET utf8mb4 COLLATE 
utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE 
_tool_sonarqube_hotspots CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE 
_tool_sonarqube_file_metrics CONVERT TO CHARACTER SET utf8mb4 COLLATE 
utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE 
_tool_sonarqube_accounts CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE cq_projects CONVERT 
TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE cq_issues CONVERT TO 
CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE cq_issue_code_blocks 
CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+               err = basicRes.GetDal().Exec(`ALTER TABLE cq_file_metrics 
CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;`)
+               if err != nil {
+                       return err
+               }
+       }
+       return nil
+
+}
+
+func (*modifyCharacterSet) Version() uint64 {
+       return 20230316220071
+}
+
+func (*modifyCharacterSet) Name() string {
+       return "sonarqube modify character set"
+}
diff --git a/backend/plugins/sonarqube/models/migrationscripts/register.go 
b/backend/plugins/sonarqube/models/migrationscripts/register.go
index a26815ea5..63e8bcc23 100644
--- a/backend/plugins/sonarqube/models/migrationscripts/register.go
+++ b/backend/plugins/sonarqube/models/migrationscripts/register.go
@@ -23,5 +23,6 @@ import "github.com/apache/incubator-devlake/core/plugin"
 func All() []plugin.MigrationScript {
        return []plugin.MigrationScript{
                new(addInitTables),
+               new(modifyCharacterSet),
        }
 }

Reply via email to