This repository has been archived by the owner on Mar 11, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 86
Adds WIT parameter in TrackerQuery payload #2360
Merged
DhritiShikhar
merged 26 commits into
fabric8-services:master
from
DhritiShikhar:tq-wit-1
Dec 21, 2018
Merged
Changes from 12 commits
Commits
Show all changes
26 commits
Select commit
Hold shift + click to select a range
f0fc73c
Adds WIT to TQ payload
DhritiShikhar 65b3643
Merge remote-tracking branch 'upstream/master' into tq-wit-1
DhritiShikhar e4f054c
adds check for WIT; adds tests
DhritiShikhar 21ee0b5
adds require.NoError
DhritiShikhar bba6209
removes duplicate checks for TrackerQuery update action
DhritiShikhar 0524fee
replaces `rest` with `s`
DhritiShikhar 5c24211
uses app.NewSpaceRelation(....)
DhritiShikhar 4e28161
changes `baseType` to `workItemType` in TrackerQuery payload
DhritiShikhar 7eafcf3
removes unnecessary spacetemplate creation
DhritiShikhar 936cfc9
uses app.NewSpaceRelation(....) for space
DhritiShikhar 68498a6
Adds work_item_type_id to existing tracker_queries; Adds tests;
DhritiShikhar 3646533
Merge remote-tracking branch 'upstream/master' into tq-wit-1
DhritiShikhar 72bc5c5
Adds struct tags
DhritiShikhar 6648376
changes name of a function
DhritiShikhar 071fe92
removes t:=s.T() line controller level test
DhritiShikhar 97f2247
deletes old data from tracker_queries; adds wit column in tracker_que…
DhritiShikhar 6f48605
removes unnecessary code from migration black box tests
DhritiShikhar e358263
Merge branch 'master' into tq-wit-1
DhritiShikhar 6ddb69d
renames function
DhritiShikhar 92a0e2c
Merge remote-tracking branch 'origin/tq-wit-1' into tq-wit-1
DhritiShikhar f5c9755
Merge remote-tracking branch 'upstream/master' into tq-wit-1
DhritiShikhar fc1a8ba
Merge branch 'master' into tq-wit-1
DhritiShikhar 1b36616
changes assert to require
DhritiShikhar 09a0e75
adds return values for tests
DhritiShikhar a59a40b
puts tests under one function
DhritiShikhar 9fd13d7
Merge remote-tracking branch 'upstream/master' into tq-wit-1
DhritiShikhar File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -14,7 +14,6 @@ import ( | |
"github.com/fabric8-services/fabric8-wit/jsonapi" | ||
"github.com/fabric8-services/fabric8-wit/remoteworkitem" | ||
"github.com/fabric8-services/fabric8-wit/resource" | ||
"github.com/fabric8-services/fabric8-wit/space" | ||
testsupport "github.com/fabric8-services/fabric8-wit/test" | ||
tf "github.com/fabric8-services/fabric8-wit/test/testfixture" | ||
testtoken "github.com/fabric8-services/fabric8-wit/test/token" | ||
|
@@ -36,20 +35,20 @@ func TestRunTrackerQueryREST(t *testing.T) { | |
suite.Run(t, &TestTrackerQueryREST{DBTestSuite: gormtestsupport.NewDBTestSuite()}) | ||
} | ||
|
||
func (rest *TestTrackerQueryREST) SetupTest() { | ||
rest.DBTestSuite.SetupTest() | ||
rest.RwiScheduler = remoteworkitem.NewScheduler(rest.DB) | ||
rest.db = gormapplication.NewGormDB(rest.DB) | ||
func (s *TestTrackerQueryREST) SetupTest() { | ||
s.DBTestSuite.SetupTest() | ||
s.RwiScheduler = remoteworkitem.NewScheduler(s.DB) | ||
s.db = gormapplication.NewGormDB(s.DB) | ||
} | ||
|
||
func (rest *TestTrackerQueryREST) SecuredController() (*goa.Service, *TrackerController, *TrackerqueryController) { | ||
func (s *TestTrackerQueryREST) SecuredController() (*goa.Service, *TrackerController, *TrackerqueryController) { | ||
svc := testsupport.ServiceAsUser("TrackerQuery-Service", testsupport.TestIdentity) | ||
return svc, NewTrackerController(svc, rest.db, rest.RwiScheduler, rest.Configuration), NewTrackerqueryController(svc, rest.db, rest.RwiScheduler, rest.Configuration) | ||
return svc, NewTrackerController(svc, s.db, s.RwiScheduler, s.Configuration), NewTrackerqueryController(svc, s.db, s.RwiScheduler, s.Configuration) | ||
} | ||
|
||
func (rest *TestTrackerQueryREST) UnSecuredController() (*goa.Service, *TrackerController, *TrackerqueryController) { | ||
func (s *TestTrackerQueryREST) UnSecuredController() (*goa.Service, *TrackerController, *TrackerqueryController) { | ||
svc := goa.New("TrackerQuery-Service") | ||
return svc, NewTrackerController(svc, rest.db, rest.RwiScheduler, rest.Configuration), NewTrackerqueryController(svc, rest.db, rest.RwiScheduler, rest.Configuration) | ||
return svc, NewTrackerController(svc, s.db, s.RwiScheduler, s.Configuration), NewTrackerqueryController(svc, s.db, s.RwiScheduler, s.Configuration) | ||
} | ||
|
||
func getTrackerQueryTestData(t *testing.T) []testSecureAPI { | ||
|
@@ -164,65 +163,61 @@ func getTrackerQueryTestData(t *testing.T) []testSecureAPI { | |
} | ||
|
||
// This test case will check authorized access to Create/Update/Delete APIs | ||
func (rest *TestTrackerQueryREST) TestUnauthorizeTrackerQueryCUD() { | ||
UnauthorizeCreateUpdateDeleteTest(rest.T(), getTrackerQueryTestData, func() *goa.Service { | ||
func (s *TestTrackerQueryREST) TestUnauthorizeTrackerQueryCUD() { | ||
UnauthorizeCreateUpdateDeleteTest(s.T(), getTrackerQueryTestData, func() *goa.Service { | ||
return goa.New("TestUnauthorizedTrackerQuery-Service") | ||
}, func(service *goa.Service) error { | ||
controller := NewTrackerqueryController(service, rest.GormDB, rest.RwiScheduler, rest.Configuration) | ||
controller := NewTrackerqueryController(service, s.GormDB, s.RwiScheduler, s.Configuration) | ||
app.MountTrackerqueryController(service, controller) | ||
return nil | ||
}) | ||
} | ||
|
||
func (rest *TestTrackerQueryREST) TestCreateTrackerQuery() { | ||
t := rest.T() | ||
func (s *TestTrackerQueryREST) TestCreateTrackerQuery() { | ||
t := s.T() | ||
resource.Require(t, resource.Database) | ||
|
||
svc, _, trackerQueryCtrl := rest.SecuredController() | ||
fxt := tf.NewTestFixture(t, rest.DB, tf.Spaces(1), tf.Trackers(1)) | ||
svc, _, trackerQueryCtrl := s.SecuredController() | ||
fxt := tf.NewTestFixture(t, s.DB, tf.Spaces(1), tf.Trackers(1), tf.WorkItemTypes(1)) | ||
assert.NotNil(t, fxt.Spaces[0], fxt.Trackers[0]) | ||
|
||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID) | ||
|
||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, fxt.WorkItemTypes[0].ID) | ||
_, tqresult := test.CreateTrackerqueryCreated(t, svc.Context, svc, trackerQueryCtrl, &tqpayload) | ||
assert.NotNil(t, tqresult) | ||
} | ||
|
||
func (rest *TestTrackerQueryREST) TestShowTrackerQuery() { | ||
t := rest.T() | ||
func (s *TestTrackerQueryREST) TestShowTrackerQuery() { | ||
t := s.T() | ||
resource.Require(t, resource.Database) | ||
|
||
svc, _, trackerQueryCtrl := rest.SecuredController() | ||
fxt := tf.NewTestFixture(t, rest.DB, tf.Spaces(1), tf.Trackers(1)) | ||
svc, _, trackerQueryCtrl := s.SecuredController() | ||
fxt := tf.NewTestFixture(t, s.DB, tf.Spaces(1), tf.Trackers(1), tf.WorkItemTypes(1)) | ||
assert.NotNil(t, fxt.Spaces[0], fxt.Trackers[0]) | ||
|
||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID) | ||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, fxt.WorkItemTypes[0].ID) | ||
|
||
_, tqresult := test.CreateTrackerqueryCreated(t, svc.Context, svc, trackerQueryCtrl, &tqpayload) | ||
|
||
_, tqr := test.ShowTrackerqueryOK(t, svc.Context, svc, trackerQueryCtrl, *tqresult.Data.ID) | ||
assert.NotNil(t, tqr) | ||
assert.Equal(t, tqresult.Data.ID, tqr.Data.ID) | ||
} | ||
|
||
func (rest *TestTrackerQueryREST) TestUpdateTrackerQuery() { | ||
t := rest.T() | ||
func (s *TestTrackerQueryREST) TestUpdateTrackerQuery() { | ||
t := s.T() | ||
resource.Require(t, resource.Database) | ||
|
||
svc, _, trackerQueryCtrl := rest.SecuredController() | ||
fxt := tf.NewTestFixture(t, rest.DB, tf.Spaces(1), tf.Trackers(1)) | ||
svc, _, trackerQueryCtrl := s.SecuredController() | ||
fxt := tf.NewTestFixture(t, s.DB, tf.Spaces(1), tf.Trackers(1), tf.WorkItemTypes(1)) | ||
assert.NotNil(t, fxt.Spaces[0], fxt.Trackers[0]) | ||
|
||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID) | ||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, fxt.WorkItemTypes[0].ID) | ||
|
||
_, tqresult := test.CreateTrackerqueryCreated(t, svc.Context, svc, trackerQueryCtrl, &tqpayload) | ||
|
||
_, tqr := test.ShowTrackerqueryOK(t, svc.Context, svc, trackerQueryCtrl, *tqresult.Data.ID) | ||
assert.NotNil(t, tqr) | ||
assert.Equal(t, tqresult.Data.ID, tqr.Data.ID) | ||
|
||
spaceID := space.SystemSpace | ||
trackerID := fxt.Trackers[0].ID | ||
payload2 := app.UpdateTrackerqueryPayload{ | ||
Data: &app.TrackerQuery{ | ||
ID: tqr.Data.ID, | ||
|
@@ -231,17 +226,19 @@ func (rest *TestTrackerQueryREST) TestUpdateTrackerQuery() { | |
Schedule: "* * * * * *", | ||
}, | ||
Relationships: &app.TrackerQueryRelations{ | ||
Space: &app.RelationSpaces{ | ||
Data: &app.RelationSpacesData{ | ||
ID: &spaceID, | ||
}, | ||
}, | ||
Space: app.NewSpaceRelation(fxt.Spaces[0].ID, ""), | ||
Tracker: &app.RelationKindUUID{ | ||
Data: &app.DataKindUUID{ | ||
ID: trackerID, | ||
ID: fxt.Trackers[0].ID, | ||
Type: remoteworkitem.APIStringTypeTrackers, | ||
}, | ||
}, | ||
WorkItemType: &app.RelationBaseType{ | ||
Data: &app.BaseTypeData{ | ||
ID: fxt.WorkItemTypes[0].ID, | ||
Type: APIStringTypeWorkItemType, | ||
}, | ||
}, | ||
}, | ||
Type: remoteworkitem.APIStringTypeTrackerQuery, | ||
}, | ||
|
@@ -255,19 +252,19 @@ func (rest *TestTrackerQueryREST) TestUpdateTrackerQuery() { | |
} | ||
|
||
// This test ensures that List does not return NIL items. | ||
func (rest *TestTrackerQueryREST) TestTrackerQueryListItemsNotNil() { | ||
t := rest.T() | ||
func (s *TestTrackerQueryREST) TestTrackerQueryListItemsNotNil() { | ||
t := s.T() | ||
resource.Require(t, resource.Database) | ||
|
||
svc, _, trackerQueryCtrl := rest.SecuredController() | ||
fxt := tf.NewTestFixture(t, rest.DB, tf.Spaces(1), tf.Trackers(1)) | ||
svc, _, trackerQueryCtrl := s.SecuredController() | ||
fxt := tf.NewTestFixture(t, s.DB, tf.Spaces(1), tf.Trackers(1), tf.WorkItemTypes(1)) | ||
assert.NotNil(t, fxt.Spaces[0], fxt.Trackers[0]) | ||
|
||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID) | ||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, fxt.WorkItemTypes[0].ID) | ||
_, tq1 := test.CreateTrackerqueryCreated(t, svc.Context, svc, trackerQueryCtrl, &tqpayload) | ||
assert.NotNil(t, tq1) | ||
|
||
tqpayload2 := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID) | ||
tqpayload2 := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, fxt.WorkItemTypes[0].ID) | ||
_, tq2 := test.CreateTrackerqueryCreated(t, svc.Context, svc, trackerQueryCtrl, &tqpayload2) | ||
assert.NotNil(t, tq2) | ||
|
||
|
@@ -277,31 +274,62 @@ func (rest *TestTrackerQueryREST) TestTrackerQueryListItemsNotNil() { | |
|
||
// This test ensures that ID returned by Show is valid. | ||
// refer : https://github.com/fabric8-services/fabric8-wit/issues/189 | ||
func (rest *TestTrackerQueryREST) TestCreateTrackerQueryID() { | ||
t := rest.T() | ||
func (s *TestTrackerQueryREST) TestCreateTrackerQueryID() { | ||
t := s.T() | ||
resource.Require(t, resource.Database) | ||
|
||
svc, _, trackerQueryCtrl := rest.SecuredController() | ||
fxt := tf.NewTestFixture(t, rest.DB, tf.Spaces(1), tf.Trackers(1)) | ||
svc, _, trackerQueryCtrl := s.SecuredController() | ||
fxt := tf.NewTestFixture(t, s.DB, tf.Spaces(1), tf.Trackers(1), tf.WorkItemTypes(1)) | ||
|
||
rest.T().Run("valid - success", func(t *testing.T) { | ||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID) | ||
s.T().Run("valid - success", func(t *testing.T) { | ||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, fxt.WorkItemTypes[0].ID) | ||
_, trackerquery := test.CreateTrackerqueryCreated(t, svc.Context, svc, trackerQueryCtrl, &tqpayload) | ||
require.NotNil(t, trackerquery) | ||
|
||
_, result := test.ShowTrackerqueryOK(t, svc.Context, svc, trackerQueryCtrl, *trackerquery.Data.ID) | ||
require.NotNil(t, result) | ||
assert.Equal(t, trackerquery.Data.ID, result.Data.ID) | ||
}) | ||
rest.T().Run("invalid - fail", func(t *testing.T) { | ||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID) | ||
s.T().Run("invalid - fail", func(t *testing.T) { | ||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, fxt.WorkItemTypes[0].ID) | ||
invalidID := uuid.Nil | ||
tqpayload.Data.ID = &invalidID | ||
test.CreateTrackerqueryBadRequest(t, svc.Context, svc, trackerQueryCtrl, &tqpayload) | ||
}) | ||
} | ||
|
||
func newCreateTrackerQueryPayload(spaceID uuid.UUID, trackerID uuid.UUID) app.CreateTrackerqueryPayload { | ||
func (s *TestTrackerQueryREST) TestInvalidWITinTrackerQuery() { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why not have one There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
t := s.T() | ||
resource.Require(t, resource.Database) | ||
s.T().Run("nil WIT in trackerquery payload", func(t *testing.T) { | ||
fxt := tf.NewTestFixture(t, s.DB, | ||
tf.Spaces(1), | ||
tf.Trackers(1), | ||
) | ||
svc, _, trackerQueryCtrl := s.SecuredController() | ||
|
||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, uuid.Nil) | ||
test.CreateTrackerqueryBadRequest(t, svc.Context, svc, trackerQueryCtrl, &tqpayload) | ||
}) | ||
|
||
s.T().Run("disallow creation if WIT belongs to different spacetemplate", func(t *testing.T) { | ||
fxt := tf.NewTestFixture(t, s.DB, | ||
tf.SpaceTemplates(2), | ||
tf.Spaces(1), | ||
tf.WorkItemTypes(1, func(fxt *tf.TestFixture, idx int) error { | ||
fxt.WorkItemTypes[idx].SpaceTemplateID = fxt.SpaceTemplates[1].ID | ||
return nil | ||
}), | ||
tf.Trackers(1), | ||
) | ||
svc, _, trackerQueryCtrl := s.SecuredController() | ||
|
||
tqpayload := newCreateTrackerQueryPayload(fxt.Spaces[0].ID, fxt.Trackers[0].ID, fxt.WorkItemTypes[0].ID) | ||
test.CreateTrackerqueryBadRequest(t, svc.Context, svc, trackerQueryCtrl, &tqpayload) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Don't these test methods have return values that you can check? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
}) | ||
} | ||
|
||
func newCreateTrackerQueryPayload(spaceID uuid.UUID, trackerID uuid.UUID, witID uuid.UUID) app.CreateTrackerqueryPayload { | ||
trackerQueryID := uuid.NewV4() | ||
return app.CreateTrackerqueryPayload{ | ||
Data: &app.TrackerQuery{ | ||
|
@@ -311,17 +339,19 @@ func newCreateTrackerQueryPayload(spaceID uuid.UUID, trackerID uuid.UUID) app.Cr | |
Schedule: "15 * * * * *", | ||
}, | ||
Relationships: &app.TrackerQueryRelations{ | ||
Space: &app.RelationSpaces{ | ||
Data: &app.RelationSpacesData{ | ||
ID: &spaceID, | ||
}, | ||
}, | ||
Space: app.NewSpaceRelation(spaceID, ""), | ||
Tracker: &app.RelationKindUUID{ | ||
Data: &app.DataKindUUID{ | ||
ID: trackerID, | ||
Type: remoteworkitem.APIStringTypeTrackers, | ||
}, | ||
}, | ||
WorkItemType: &app.RelationBaseType{ | ||
Data: &app.BaseTypeData{ | ||
ID: witID, | ||
Type: APIStringTypeWorkItemType, | ||
}, | ||
}, | ||
}, | ||
Type: remoteworkitem.APIStringTypeTrackerQuery, | ||
}, | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wonder whether the UUID should be validated.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@baijum are you talking about a check if the
id
contains string or uuid?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Check whether the value of
*ctx.Payload.Data.ID
is real UUID (It's not a string type)There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I mean what if the value is some random string. It will reach the database layer and fail. How about failing early?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@baijum At design level itself its specified that the value should be a UUID (https://github.com/fabric8-services/fabric8-wit/blob/master/design/tracker_queries.go#L13)