This is an automated email from the ASF dual-hosted git repository.
abeizn pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/incubator-devlake.git
The following commit(s) were added to refs/heads/main by this push:
new e53579ec3 fix: milestone created_at and updated_at (#6274)
e53579ec3 is described below
commit e53579ec3c04f740343572c8014981371cfd0ff0
Author: abeizn <[email protected]>
AuthorDate: Wed Oct 18 03:03:36 2023 -0500
fix: milestone created_at and updated_at (#6274)
---
.../20231018_modify_tool_github_milestones.go | 70 ++++++++++++++++++++++
.../github/models/migrationscripts/register.go | 1 +
backend/plugins/github/models/milestone.go | 27 +++++----
.../plugins/github/tasks/milestone_converter.go | 2 +-
.../plugins/github/tasks/milestone_extractor.go | 24 ++++----
5 files changed, 98 insertions(+), 26 deletions(-)
diff --git
a/backend/plugins/github/models/migrationscripts/20231018_modify_tool_github_milestones.go
b/backend/plugins/github/models/migrationscripts/20231018_modify_tool_github_milestones.go
new file mode 100644
index 000000000..8be924939
--- /dev/null
+++
b/backend/plugins/github/models/migrationscripts/20231018_modify_tool_github_milestones.go
@@ -0,0 +1,70 @@
+/*
+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 (
+ "time"
+
+ "github.com/apache/incubator-devlake/core/context"
+ "github.com/apache/incubator-devlake/core/errors"
+
"github.com/apache/incubator-devlake/core/models/migrationscripts/archived"
+ "github.com/apache/incubator-devlake/helpers/migrationhelper"
+ githubArchived
"github.com/apache/incubator-devlake/plugins/github/models/migrationscripts/archived"
+)
+
+type modifyGithubMilestone struct{}
+
+type GithubMilestone20231018 struct {
+ ConnectionId uint64 `gorm:"primaryKey"`
+ MilestoneId int `gorm:"primaryKey;autoIncrement:false"`
+ RepoId int
+ Number int
+ URL string
+ Title string
+ OpenIssues int
+ ClosedIssues int
+ State string
+ GithubCreatedAt time.Time
+ GithubUpdatedAt time.Time
+ ClosedAt *time.Time
+
+ archived.NoPKModel
+}
+
+func (GithubMilestone20231018) TableName() string {
+ return "_tool_github_milestones"
+}
+
+func (script *modifyGithubMilestone) Up(basicRes context.BasicRes)
errors.Error {
+ err := basicRes.GetDal().DropTables(&githubArchived.GithubMilestone{})
+ if err != nil {
+ return err
+ }
+ return migrationhelper.AutoMigrateTables(
+ basicRes,
+ &GithubMilestone20231018{},
+ )
+}
+
+func (*modifyGithubMilestone) Version() uint64 {
+ return 20231018122537
+}
+
+func (*modifyGithubMilestone) Name() string {
+ return "modify _tool_github_milestones table created_at and updated_at"
+}
diff --git a/backend/plugins/github/models/migrationscripts/register.go
b/backend/plugins/github/models/migrationscripts/register.go
index e8dc5b0df..c101043bd 100644
--- a/backend/plugins/github/models/migrationscripts/register.go
+++ b/backend/plugins/github/models/migrationscripts/register.go
@@ -44,5 +44,6 @@ func All() []plugin.MigrationScript {
new(addFullName),
new(addRawParamTableForScope),
new(addDeploymentTable),
+ new(modifyGithubMilestone),
}
}
diff --git a/backend/plugins/github/models/milestone.go
b/backend/plugins/github/models/milestone.go
index 4fadfca12..94a5aebd5 100644
--- a/backend/plugins/github/models/milestone.go
+++ b/backend/plugins/github/models/milestone.go
@@ -18,23 +18,24 @@ limitations under the License.
package models
import (
- "github.com/apache/incubator-devlake/core/models/common"
"time"
+
+ "github.com/apache/incubator-devlake/core/models/common"
)
type GithubMilestone struct {
- ConnectionId uint64 `gorm:"primaryKey"`
- MilestoneId int `gorm:"primaryKey;autoIncrement:false"`
- RepoId int
- Number int
- URL string
- Title string
- OpenIssues int
- ClosedIssues int
- State string
- CreatedAt time.Time
- UpdatedAt time.Time
- ClosedAt *time.Time
+ ConnectionId uint64 `gorm:"primaryKey"`
+ MilestoneId int `gorm:"primaryKey;autoIncrement:false"`
+ RepoId int
+ Number int
+ URL string
+ Title string
+ OpenIssues int
+ ClosedIssues int
+ State string
+ GithubCreatedAt time.Time
+ GithubUpdatedAt time.Time
+ ClosedAt *time.Time
common.NoPKModel
}
diff --git a/backend/plugins/github/tasks/milestone_converter.go
b/backend/plugins/github/tasks/milestone_converter.go
index 8b97beee5..6d872023d 100644
--- a/backend/plugins/github/tasks/milestone_converter.go
+++ b/backend/plugins/github/tasks/milestone_converter.go
@@ -100,7 +100,7 @@ func ConvertMilestones(taskCtx plugin.SubTaskContext)
errors.Error {
Name: response.GithubMilestone.Title,
Url: response.GithubMilestone.URL,
Status: response.GithubMilestone.State,
- StartedDate:
&response.GithubMilestone.CreatedAt, //GitHub doesn't give us a "start date"
+ StartedDate:
&response.GithubMilestone.GithubCreatedAt, //GitHub doesn't give us a "start
date"
EndedDate:
response.GithubMilestone.ClosedAt,
CompletedDate:
response.GithubMilestone.ClosedAt,
OriginalBoardID: domainBoardId,
diff --git a/backend/plugins/github/tasks/milestone_extractor.go
b/backend/plugins/github/tasks/milestone_extractor.go
index 28ea60063..83e10b5cd 100644
--- a/backend/plugins/github/tasks/milestone_extractor.go
+++ b/backend/plugins/github/tasks/milestone_extractor.go
@@ -110,18 +110,18 @@ func ExtractMilestones(taskCtx plugin.SubTaskContext)
errors.Error {
func convertGithubMilestone(response *MilestonesResponse, connectionId uint64,
repositoryId int) *models.GithubMilestone {
milestone := &models.GithubMilestone{
- ConnectionId: connectionId,
- MilestoneId: response.Id,
- RepoId: repositoryId,
- Number: response.Number,
- URL: response.Url,
- Title: response.Title,
- OpenIssues: response.OpenIssues,
- ClosedIssues: response.ClosedIssues,
- State: response.State,
- ClosedAt: common.Iso8601TimeToTime(response.ClosedAt),
- CreatedAt: response.CreatedAt.ToTime(),
- UpdatedAt: response.UpdatedAt.ToTime(),
+ ConnectionId: connectionId,
+ MilestoneId: response.Id,
+ RepoId: repositoryId,
+ Number: response.Number,
+ URL: response.Url,
+ Title: response.Title,
+ OpenIssues: response.OpenIssues,
+ ClosedIssues: response.ClosedIssues,
+ State: response.State,
+ ClosedAt: common.Iso8601TimeToTime(response.ClosedAt),
+ GithubCreatedAt: response.CreatedAt.ToTime(),
+ GithubUpdatedAt: response.UpdatedAt.ToTime(),
}
return milestone
}