From c73d53e1880a839d2f1a98834b33d2cc8f7b7b20 Mon Sep 17 00:00:00 2001
From: Kenia <19161242+kaxcode@users.noreply.github.com>
Date: Tue, 28 Jul 2020 11:06:32 -0400
Subject: [PATCH] ui: Add sorting to Intentions with tests (#8348)
* Add sorting to Intentions with tests
* Skip Intentions url back test
* Create comparator for intention and implement in template
* Add a intentions navigation feature test
---
ui-v2/app/controllers/dc/intentions/index.js | 4 +-
ui-v2/app/initializers/sort.js | 2 +
ui-v2/app/routes/dc/intentions/index.js | 4 +-
ui-v2/app/sort/comparators/intention.js | 3 +
ui-v2/app/templates/dc/intentions/index.hbs | 32 ++++++-----
.../components/intention-filter.feature | 55 -------------------
.../dc/intentions/navigation.feature | 30 ++++++++++
.../acceptance/dc/intentions/sorting.feature | 42 ++++++++++++++
.../tests/acceptance/page-navigation.feature | 3 +-
.../intentions/navigation-steps.js} | 2 +-
.../steps/dc/intentions/sorting-steps.js | 10 ++++
ui-v2/tests/pages.js | 8 +--
ui-v2/tests/pages/dc/intentions/index.js | 5 +-
13 files changed, 114 insertions(+), 86 deletions(-)
create mode 100644 ui-v2/app/sort/comparators/intention.js
delete mode 100644 ui-v2/tests/acceptance/components/intention-filter.feature
create mode 100644 ui-v2/tests/acceptance/dc/intentions/navigation.feature
create mode 100644 ui-v2/tests/acceptance/dc/intentions/sorting.feature
rename ui-v2/tests/acceptance/steps/{components/intention-filter-steps.js => dc/intentions/navigation-steps.js} (88%)
create mode 100644 ui-v2/tests/acceptance/steps/dc/intentions/sorting-steps.js
diff --git a/ui-v2/app/controllers/dc/intentions/index.js b/ui-v2/app/controllers/dc/intentions/index.js
index 3407bfeef8..f99cde37f3 100644
--- a/ui-v2/app/controllers/dc/intentions/index.js
+++ b/ui-v2/app/controllers/dc/intentions/index.js
@@ -1,9 +1,7 @@
import Controller from '@ember/controller';
export default Controller.extend({
queryParams: {
- filterBy: {
- as: 'action',
- },
+ sortBy: 'sort',
search: {
as: 'filter',
replace: true,
diff --git a/ui-v2/app/initializers/sort.js b/ui-v2/app/initializers/sort.js
index 6ddcc3ef86..464abe4d18 100644
--- a/ui-v2/app/initializers/sort.js
+++ b/ui-v2/app/initializers/sort.js
@@ -1,5 +1,6 @@
import service from 'consul-ui/sort/comparators/service';
import check from 'consul-ui/sort/comparators/check';
+import intention from 'consul-ui/sort/comparators/intention';
export function initialize(container) {
// Service-less injection using private properties at a per-project level
@@ -7,6 +8,7 @@ export function initialize(container) {
const comparators = {
service: service(),
check: check(),
+ intention: intention(),
};
Sort.reopen({
comparator: function(type) {
diff --git a/ui-v2/app/routes/dc/intentions/index.js b/ui-v2/app/routes/dc/intentions/index.js
index d62d3c00aa..16284be807 100644
--- a/ui-v2/app/routes/dc/intentions/index.js
+++ b/ui-v2/app/routes/dc/intentions/index.js
@@ -2,9 +2,7 @@ import Route from '@ember/routing/route';
export default Route.extend({
queryParams: {
- filterBy: {
- as: 'action',
- },
+ sortBy: 'sort',
search: {
as: 'filter',
replace: true,
diff --git a/ui-v2/app/sort/comparators/intention.js b/ui-v2/app/sort/comparators/intention.js
new file mode 100644
index 0000000000..62e718f7a1
--- /dev/null
+++ b/ui-v2/app/sort/comparators/intention.js
@@ -0,0 +1,3 @@
+export default () => key => {
+ return key;
+};
diff --git a/ui-v2/app/templates/dc/intentions/index.hbs b/ui-v2/app/templates/dc/intentions/index.hbs
index dff4f8949a..1d076c7b88 100644
--- a/ui-v2/app/templates/dc/intentions/index.hbs
+++ b/ui-v2/app/templates/dc/intentions/index.hbs
@@ -7,14 +7,18 @@
- {{#let (filter-by "Action" "deny" api.data) as |denied|}}
{{#let (selectable-key-values
- (array "" (concat "All (" api.data.length ")"))
- (array "allow" (concat "Allow (" (sub api.data.length denied.length) ")"))
- (array "deny" (concat "Deny (" denied.length ")"))
- selected=filterBy
+ (array "Action:asc" "Allow to Deny")
+ (array "Action:desc" "Deny to Allow")
+ (array "SourceName:asc" "Source: A to Z")
+ (array "SourceName:desc" "Source: Z to A")
+ (array "DestinationName:asc" "Destination: A to Z")
+ (array "DestinationName:desc" "Destination: Z to A")
+ (array "Precedence:asc" "Precedence: Asc")
+ (array "Precedence:desc" "Precedence: Desc")
+ selected=sortBy
)
- as |filter|
+ as |sort|
}}
@@ -33,15 +37,16 @@
data-test-intention-filter="true"
@value={{search}}
@onsearch={{action (mut search) value="target.value"}}
- @selected={{filter.selected}}
- @options={{filter.items}}
- @onchange={{action (mut filterBy) value='target.value'}}
+ @secondary="sort"
+ @selected={{sort.selected}}
+ @options={{sort.items}}
+ @onchange={{action (mut sortBy) value='target.value'}}
/>
{{/if}}
-
-
+ {{#let (sort-by (comparator 'intention' sort.selected.key) api.data) as |sorted|}}
+
-
+ {{/let}}
-
{{/let}}
- {{/let}}
-
\ No newline at end of file
diff --git a/ui-v2/tests/acceptance/components/intention-filter.feature b/ui-v2/tests/acceptance/components/intention-filter.feature
deleted file mode 100644
index d8acd9aff3..0000000000
--- a/ui-v2/tests/acceptance/components/intention-filter.feature
+++ /dev/null
@@ -1,55 +0,0 @@
-@setupApplicationTest
-Feature: components / intention-filter: Intention Filter
- In order to find the intention I'm looking for easier
- As a user
- I should be able to filter by 'policy' (allow/deny) and freetext search tokens by source and destination
- Scenario: Filtering [Model]
- Given 1 datacenter model with the value "dc-1"
- And 2 [Model] models
- When I visit the [Page] page for yaml
- ---
- dc: dc-1
- ---
- Then the url should be [Url]
-
- Then I see 2 [Model] models
- And I see allIsSelected on the filter
-
- When I click allow on the filter
- Then I see allowIsSelected on the filter
- And I see 1 [Model] model
- And I see 1 [Model] model with the action "allow"
-
- When I click deny on the filter
- Then I see denyIsSelected on the filter
- And I see 1 [Model] model
- And I see 1 [Model] model with the action "deny"
-
- When I click all on the filter
- Then I see 2 [Model] models
- Then I see allIsSelected on the filter
- Then I fill in with yaml
- ---
- s: alarm
- ---
- And I see 1 [Model] model
- And I see 1 [Model] model with the source "alarm"
- Then I fill in with yaml
- ---
- s: feed
- ---
- And I see 1 [Model] model
- And I see 1 [Model] model with the destination "feed"
- Then I fill in with yaml
- ---
- s: transmitter
- ---
- And I see 2 [Model] models
- And I see 1 [Model] model with the source "transmitter"
- And I see 1 [Model] model with the destination "transmitter"
-
- Where:
- ---------------------------------------------
- | Model | Page | Url |
- | intention | intentions | /dc-1/intentions |
- ---------------------------------------------
diff --git a/ui-v2/tests/acceptance/dc/intentions/navigation.feature b/ui-v2/tests/acceptance/dc/intentions/navigation.feature
new file mode 100644
index 0000000000..76e24d0341
--- /dev/null
+++ b/ui-v2/tests/acceptance/dc/intentions/navigation.feature
@@ -0,0 +1,30 @@
+@setupApplicationTest
+Feature: dc / intentions / navigation
+ Scenario: Clicking a intention in the listing and back again
+ Given 1 datacenter model with the value "dc-1"
+ And 3 intention models
+ When I visit the intentions page for yaml
+ ---
+ dc: dc-1
+ ---
+ Then the url should be /dc-1/intentions
+ And the title should be "Intentions - Consul"
+ Then I see 3 intention models
+ When I click intention on the intentions
+ Then a GET request was made to "/v1/internal/ui/services?dc=dc-1&ns=*"
+ And I click "[data-test-back]"
+ Then the url should be /dc-1/intentions
+ Scenario: Clicking the create button and back again
+ Given 1 datacenter model with the value "dc-1"
+ And 3 intention models
+ When I visit the intentions page for yaml
+ ---
+ dc: dc-1
+ ---
+ Then the url should be /dc-1/intentions
+ And the title should be "Intentions - Consul"
+ Then I see 3 intention models
+ When I click create
+ Then the url should be /dc-1/intentions/create
+ And I click "[data-test-back]"
+ Then the url should be /dc-1/intentions
diff --git a/ui-v2/tests/acceptance/dc/intentions/sorting.feature b/ui-v2/tests/acceptance/dc/intentions/sorting.feature
new file mode 100644
index 0000000000..8575c60443
--- /dev/null
+++ b/ui-v2/tests/acceptance/dc/intentions/sorting.feature
@@ -0,0 +1,42 @@
+@setupApplicationTest
+@notNamespaceable
+Feature: dc / intentions / sorting
+ Scenario: Sorting Intentions
+ Given 1 datacenter model with the value "dc-1"
+ And 6 intention models from yaml
+ ---
+ - Action: "allow"
+ - Action: "allow"
+ - Action: "deny"
+ - Action: "deny"
+ - Action: "allow"
+ - Action: "deny"
+ ---
+ When I visit the intentions page for yaml
+ ---
+ dc: dc-1
+ ---
+ Then I see 6 intention models
+ When I click selected on the sort
+ When I click options.1.button on the sort
+ Then I see action on the intentions vertically like yaml
+ ---
+ - "deny"
+ - "deny"
+ - "deny"
+ - "allow"
+ - "allow"
+ - "allow"
+ ---
+ When I click selected on the sort
+ When I click options.0.button on the sort
+ Then I see action on the intentions vertically like yaml
+ ---
+ - "allow"
+ - "allow"
+ - "allow"
+ - "deny"
+ - "deny"
+ - "deny"
+ ---
+
diff --git a/ui-v2/tests/acceptance/page-navigation.feature b/ui-v2/tests/acceptance/page-navigation.feature
index f4e0e15b5f..c2648c77b3 100644
--- a/ui-v2/tests/acceptance/page-navigation.feature
+++ b/ui-v2/tests/acceptance/page-navigation.feature
@@ -46,7 +46,6 @@ Feature: page-navigation
| node | nodes | /dc-1/nodes/node-0/health-checks | /v1/session/node/node-0?dc=dc-1&ns=@namespace | /dc-1/nodes |
| kv | kvs | /dc-1/kv/0-key-value/edit | /v1/session/info/ee52203d-989f-4f7a-ab5a-2bef004164ca?dc=dc-1&ns=@namespace | /dc-1/kv |
# | acl | acls | /dc-1/acls/anonymous | /v1/acl/info/anonymous?dc=dc-1 | /dc-1/acls |
- | intention | intentions | /dc-1/intentions/ee52203d-989f-4f7a-ab5a-2bef004164ca | /v1/internal/ui/services?dc=dc-1&ns=* | /dc-1/intentions |
# These Endpoints will be datacenters due to the datacenters checkbox selectors
| token | tokens | /dc-1/acls/tokens/ee52203d-989f-4f7a-ab5a-2bef004164ca | /v1/catalog/datacenters | /dc-1/acls/tokens |
| policy | policies | /dc-1/acls/policies/ee52203d-989f-4f7a-ab5a-2bef004164ca | /v1/catalog/datacenters | /dc-1/acls/policies |
@@ -123,7 +122,7 @@ Feature: page-navigation
| Item | Model | URL | Back |
| kv | kvs | /dc-1/kv/0-key-value/edit | /dc-1/kv |
# | acl | acls | /dc-1/acls/anonymous | /dc-1/acls |
- | intention | intentions | /dc-1/intentions/ee52203d-989f-4f7a-ab5a-2bef004164ca | /dc-1/intentions |
+ # | intention | intentions | /dc-1/intentions/ee52203d-989f-4f7a-ab5a-2bef004164ca | /dc-1/intentions |
--------------------------------------------------------------------------------------------------------
@ignore
Scenario: Clicking items in the listings, without depending on the salt ^
diff --git a/ui-v2/tests/acceptance/steps/components/intention-filter-steps.js b/ui-v2/tests/acceptance/steps/dc/intentions/navigation-steps.js
similarity index 88%
rename from ui-v2/tests/acceptance/steps/components/intention-filter-steps.js
rename to ui-v2/tests/acceptance/steps/dc/intentions/navigation-steps.js
index 3c9a76f69f..ba1093295f 100644
--- a/ui-v2/tests/acceptance/steps/components/intention-filter-steps.js
+++ b/ui-v2/tests/acceptance/steps/dc/intentions/navigation-steps.js
@@ -1,4 +1,4 @@
-import steps from '../steps';
+import steps from '../../steps';
// step definitions that are shared between features should be moved to the
// tests/acceptance/steps/steps.js file
diff --git a/ui-v2/tests/acceptance/steps/dc/intentions/sorting-steps.js b/ui-v2/tests/acceptance/steps/dc/intentions/sorting-steps.js
new file mode 100644
index 0000000000..ba1093295f
--- /dev/null
+++ b/ui-v2/tests/acceptance/steps/dc/intentions/sorting-steps.js
@@ -0,0 +1,10 @@
+import steps from '../../steps';
+
+// step definitions that are shared between features should be moved to the
+// tests/acceptance/steps/steps.js file
+
+export default function(assert) {
+ return steps(assert).then('I should find a file', function() {
+ assert.ok(true, this.step);
+ });
+}
diff --git a/ui-v2/tests/pages.js b/ui-v2/tests/pages.js
index d22010e94d..3060bc11bf 100644
--- a/ui-v2/tests/pages.js
+++ b/ui-v2/tests/pages.js
@@ -85,10 +85,6 @@ const catalogFilter = searchBarFactory(freetextFilter, () =>
const aclFilter = searchBarFactory(freetextFilter, () =>
radiogroup('type', ['', 'management', 'client'])
);
-const intentionFilter = searchBarFactory(freetextFilter, () =>
- radiogroup('currentFilter', ['', 'allow', 'deny'])
-);
-
const policyForm = policyFormFactory(submitable, cancelable, radiogroup, text);
const policySelector = policySelectorFactory(clickable, deletable, collection, alias, policyForm);
const roleForm = roleFormFactory(submitable, cancelable, policySelector);
@@ -172,7 +168,9 @@ export default {
token: create(
token(visitable, submitable, deletable, cancelable, clickable, policySelector, roleSelector)
),
- intentions: create(intentions(visitable, creatable, consulIntentionList, intentionFilter)),
+ intentions: create(
+ intentions(visitable, creatable, clickable, consulIntentionList, popoverSelect)
+ ),
intention: create(intention(visitable, submitable, deletable, cancelable)),
nspaces: create(nspaces(visitable, creatable, consulNspaceList, freetextFilter)),
nspace: create(
diff --git a/ui-v2/tests/pages/dc/intentions/index.js b/ui-v2/tests/pages/dc/intentions/index.js
index e925ad1fc9..2c292bab1c 100644
--- a/ui-v2/tests/pages/dc/intentions/index.js
+++ b/ui-v2/tests/pages/dc/intentions/index.js
@@ -1,7 +1,8 @@
-export default function(visitable, creatable, intentions, filter) {
+export default function(visitable, creatable, clickable, intentions, popoverSelect) {
return creatable({
visit: visitable('/:dc/intentions'),
intentions: intentions(),
- filter: filter('[data-test-intention-filter]'),
+ sort: popoverSelect(),
+ create: clickable('[data-test-create]'),
});
}