Merge "e2e testing using mocks"
diff --git a/webapp-frontend/e2e/src/app.e2e-spec.ts b/webapp-frontend/e2e/src/app.e2e-spec.ts
index fb7e14f..4e01075 100644
--- a/webapp-frontend/e2e/src/app.e2e-spec.ts
+++ b/webapp-frontend/e2e/src/app.e2e-spec.ts
@@ -1,3 +1,4 @@
+import { tick } from '@angular/core/testing';
 /*-
  * ========================LICENSE_START=================================
  * O-RAN-SC
@@ -19,16 +20,125 @@
  */
 import { browser, by, element, logging } from "protractor";
 
-describe("workspace-project App", () => {
+describe("Home page", () => {
 
   beforeEach(() => {
+    browser.get("http://localhost:4200/");
   });
 
   it("should display title", () => {
-    browser.get("http://localhost:4200/");
     expect(browser.getTitle()).toEqual("Non-RT RIC Control Panel");
   });
 
+  it("should reach policy types page when clicking on the policy types card", async () => {
+    await element(by.id('policyControlCard')).click();
+    expect(browser.getCurrentUrl()).toEqual("http://localhost:4200/policy");
+  });
+
+  it("should reach enrichment information coordinator page when clicking on the enrichment information coordinator card", async () => {
+    await element(by.id('eicCard')).click();
+    expect(browser.getCurrentUrl()).toEqual("http://localhost:4200/ei-coordinator");
+  });
+
+  afterEach(async () => {
+    // Assert that there are no errors emitted from the browser
+    const logs = await browser.manage().logs().get(logging.Type.BROWSER);
+    expect(logs).not.toContain(
+      jasmine.objectContaining({
+        level: logging.Level.SEVERE,
+      })
+    );
+  });
+});
+
+describe("Sidebar navigation", () => {
+
+  beforeEach(() => {
+    browser.get("http://localhost:4200/");
+    element(by.id('Menu_Burger_Icon')).click();
+  });
+
+  it("should reach policy types page when clicking in the side bar", async () => {
+    await element(by.id('policyToggle')).click();
+    await element(by.id('policyLink')).click();
+    expect(browser.getCurrentUrl()).toEqual("http://localhost:4200/policy");
+  });
+
+  it("should reach ric configuration page when clicking in the side bar", async () => {
+    await element(by.id('policyToggle')).click();
+    await element(by.id('ricConfigLink')).click();
+    expect(browser.getCurrentUrl()).toEqual("http://localhost:4200/ric-config");
+  });
+
+  it("should reach enrichment information coordinator page when clicking in the side bar", async () => {
+    await element(by.id('eicLink')).click();
+    expect(browser.getCurrentUrl()).toEqual("http://localhost:4200/ei-coordinator");
+  });
+
+  afterEach(async () => {
+    // Assert that there are no errors emitted from the browser
+    const logs = await browser.manage().logs().get(logging.Type.BROWSER);
+    expect(logs).not.toContain(
+      jasmine.objectContaining({
+        level: logging.Level.SEVERE,
+      })
+    );
+  });
+});
+
+describe("Policy types page", () => {
+
+  beforeEach(() => {
+    browser.get("http://localhost:4200/policy");
+  });
+
+  it("should reach back to home from policy types page when clicking in the side bar", async () => {
+    await element(by.id('Menu_Burger_Icon')).click();
+    await element(by.id('homeLink')).click();
+    expect(browser.getCurrentUrl()).toEqual("http://localhost:4200/");
+  });
+
+  it("should show types when clicking on expand button in policy types page", async () => {
+    await element(by.id('visible')).click();
+    expect(element(by.id('createButton'))).toBeTruthy();
+  });
+
+  it("should display a pop-up window when clicking on the create button for a policy instance", async () => {
+    await element(by.id('visible')).click();
+    await element(by.id('createButton')).click();
+    expect(element(by.id('closeButton'))).toBeTruthy();
+  });
+
+  it("should open a pop-up window when clicking on the data of a policy instance", async () => {
+    await element(by.id('visible')).click();
+    let instanceTable = element(by.id('policiesTable'));
+    await element(by.css('mat-cell')).click();
+    expect(element(by.id('closeButton'))).toBeTruthy();
+  });
+
+  afterEach(async () => {
+    // Assert that there are no errors emitted from the browser
+    const logs = await browser.manage().logs().get(logging.Type.BROWSER);
+    expect(logs).not.toContain(
+      jasmine.objectContaining({
+        level: logging.Level.SEVERE,
+      })
+    );
+  });
+});
+
+describe("Enrichment information coordinator page", () => {
+
+  beforeEach(() => {
+    browser.get("http://localhost:4200/ei-coordinator");
+  });
+
+  it("should reach back to home from enrichment information coordinator page when clicking in the side bar", async () => {
+    await element(by.id('Menu_Burger_Icon')).click();
+    await element(by.id('homeLink')).click();
+    expect(browser.getCurrentUrl()).toEqual("http://localhost:4200/");
+  });
+
   afterEach(async () => {
     // Assert that there are no errors emitted from the browser
     const logs = await browser.manage().logs().get(logging.Type.BROWSER);
diff --git a/webapp-frontend/src/app/app.component.html b/webapp-frontend/src/app/app.component.html
index 202afc5..6c930dd 100644
--- a/webapp-frontend/src/app/app.component.html
+++ b/webapp-frontend/src/app/app.component.html
@@ -43,7 +43,7 @@
       </div>
     </section>
     <section #sidenav class="menu-body">
-      <nrcp-sidenav-list (sidenavClose)="drawer.toggle()">></nrcp-sidenav-list>
+      <nrcp-sidenav-list id="sidenavlist" (sidenavClose)="drawer.toggle()">></nrcp-sidenav-list>
     </section>
     <section class="menu-footer">
 
diff --git a/webapp-frontend/src/app/ei-coordinator/ei-card/ei-card.component.html b/webapp-frontend/src/app/ei-coordinator/ei-card/ei-card.component.html
index bdbb604..f59e7c8 100644
--- a/webapp-frontend/src/app/ei-coordinator/ei-card/ei-card.component.html
+++ b/webapp-frontend/src/app/ei-coordinator/ei-card/ei-card.component.html
@@ -19,9 +19,8 @@
   -->
   <div class="ei__card" routerLink="/ei-coordinator" [ngClass]="{'add__card-dark': darkMode}">
     <div class="header__container">
-      <span class="card__title">Enrichment Information Coordinator</span>
+      <span id="eicCard" class="card__title">Enrichment Information Coordinator</span>
     <div class="body__container">
       <img src="assets/oran-logo.png" width="250px"/>
     </div>
   </div>
-  
\ No newline at end of file
diff --git a/webapp-frontend/src/app/navigation/sidenav-list/sidenav-list.component.html b/webapp-frontend/src/app/navigation/sidenav-list/sidenav-list.component.html
index 8a34a8f..09e0f47 100644
--- a/webapp-frontend/src/app/navigation/sidenav-list/sidenav-list.component.html
+++ b/webapp-frontend/src/app/navigation/sidenav-list/sidenav-list.component.html
@@ -21,23 +21,23 @@
 
 <!-- browse icons at https://material.io/tools/icons/?style=baseline -->
 <mat-nav-list [ngClass]="{'dark': darkMode}">
-  <a mat-list-item routerLink="/" (click)="onSidenavClose()">
+  <a mat-list-item id="homeLink" routerLink="/" (click)="onSidenavClose()">
     <mat-icon>home</mat-icon> <span class="nav-caption">Home</span>
   </a>
-  <a mat-list-item (click)="toggle()">
+  <a mat-list-item id="policyToggle" (click)="toggle()">
       <mat-icon>dashboard</mat-icon> <span class="nav-caption">Policy</span>
       <mat-icon *ngIf="showSubMenu">expand_more</mat-icon>
       <mat-icon *ngIf="!showSubMenu">chevron_right</mat-icon>
   </a>
   <mat-nav-list [ngClass]="{'dark': darkMode}" *ngIf="showSubMenu">
-    <a mat-list-item routerLink="/policy" (click)="onSidenavClose()">
+    <a mat-list-item id="policyLink" routerLink="/policy" (click)="onSidenavClose()">
       <mat-icon>dashboard</mat-icon> <span class="nav-caption">Policy Types</span>
     </a>
-    <a mat-list-item routerLink="/ric-config" (click)="onSidenavClose()">
+    <a mat-list-item id="ricConfigLink" routerLink="/ric-config" (click)="onSidenavClose()">
       <mat-icon>build</mat-icon> <span class="nav-caption">RIC Config</span>
     </a>
   </mat-nav-list>
-  <a mat-list-item routerLink="/ei-coordinator" (click)="onSidenavClose()">
+  <a mat-list-item id="eicLink" routerLink="/ei-coordinator" (click)="onSidenavClose()">
     <mat-icon>dashboard</mat-icon> <span class="nav-caption">Enrichment Information Coordinator</span>
 </a>
 </mat-nav-list>
diff --git a/webapp-frontend/src/app/policy/policy-card/policy-card.component.html b/webapp-frontend/src/app/policy/policy-card/policy-card.component.html
index a0cecdf..18d9d41 100644
--- a/webapp-frontend/src/app/policy/policy-card/policy-card.component.html
+++ b/webapp-frontend/src/app/policy/policy-card/policy-card.component.html
@@ -19,7 +19,7 @@
   -->
 <div class="policy__card" routerLink="/policy" [ngClass]="{'add__card-dark': darkMode}">
   <div class="header__container">
-    <span class="card__title">Policy Control</span><br><br><br>
+    <span id="policyControlCard" class="card__title">Policy Control</span><br><br><br>
     <div class="body__container">
     <img src="assets/oran-logo.png" width="250px"/>
   </div>