Skip to content

Commit

Permalink
Modify k6 tests and add security to report
Browse files Browse the repository at this point in the history
  • Loading branch information
dannymaate committed Jun 3, 2024
1 parent fda59de commit e46d80d
Show file tree
Hide file tree
Showing 6 changed files with 38 additions and 14 deletions.
2 changes: 1 addition & 1 deletion k6_test/create_menu_item.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ export default function () {
orderable: true,
});

let createItemRes = http.post('http://localhost:8080/api/v1/menu_items', itemData, {
let createItemRes = http.post('http://brewbucks-485861802.us-east-1.elb.amazonaws.com/api/v1/menu_items', itemData, {
headers: { 'Content-Type': 'application/json' },
});

Expand Down
8 changes: 4 additions & 4 deletions k6_test/create_order.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ import { check, sleep } from 'k6';

export const options = {
stages: [
{ duration: '1m', target: 20 }, // Ramp-up to 20 users over 1 minute
{ duration: '2m', target: 20 }, // Stay at 20 users for 2 minutes
{ duration: '1m', target: 0 }, // Ramp-down to 0 users over 1 minute
{ duration: '2m', target: 1000 }, // Ramp-up to 20 users over 1 minute
{ duration: '2m', target: 2500 }, // Stay at 20 users for 2 minutes
{ duration: '2m', target: 0 }, // Ramp-down to 0 users over 1 minute
],
};

Expand All @@ -19,7 +19,7 @@ export default function () {
rewards_added: 5,
});

let createOrderRes = http.post('http://localhost:8080/api/v1/users/orders', orderData, {
let createOrderRes = http.post('http://brewbucks-485861802.us-east-1.elb.amazonaws.com/api/v1/users/orders', orderData, {
headers: { 'Content-Type': 'application/json' },
});

Expand Down
8 changes: 4 additions & 4 deletions k6_test/get_menu_item.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,20 +3,20 @@ import { check, sleep } from 'k6';

export const options = {
stages: [
{ duration: '1m', target: 20 },
{ duration: '2m', target: 20 },
{ duration: '1m', target: 45 },
{ duration: '2m', target: 75 },
{ duration: '1m', target: 0 },
],
};

export default function () {
let res = http.get('http://localhost:8080/api/v1/menu_items', {
let res = http.get('http://brewbucks-485861802.us-east-1.elb.amazonaws.com/api/v1/menu_items', {
headers: { 'Content-Type': 'application/json' },
});

check(res, {
'status is 200': (r) => r.status === 200,
'response time is < 500ms': (r) => r.timings.duration < 500,
'response time is < 750ms': (r) => r.timings.duration < 750,
});

sleep(1);
Expand Down
6 changes: 3 additions & 3 deletions k6_test/get_user_info.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,14 @@ import { check, sleep } from 'k6';

export const options = {
stages: [
{ duration: '1m', target: 20 },
{ duration: '2m', target: 20 },
{ duration: '1m', target: 1000 },
{ duration: '2m', target: 2000 },
{ duration: '1m', target: 0 },
],
};

export default function () {
let res = http.get('http://localhost:8080/api/v1/users/1', {
let res = http.get('http://brewbucks-485861802.us-east-1.elb.amazonaws.com/api/v1/users/1', {
headers: { 'Content-Type': 'application/json' },
});

Expand Down
4 changes: 2 additions & 2 deletions k6_test/sign_up_and_delete_user.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ export default function () {
role: 'customer',
});

let createUserRes = http.post('http://localhost:8080/api/v1/users', userData, {
let createUserRes = http.post('http://brewbucks-485861802.us-east-1.elb.amazonaws.com/api/v1/users', userData, {
headers: { 'Content-Type': 'application/json' },
});

Expand All @@ -37,7 +37,7 @@ export default function () {

let userId = createUserRes.json().user_id;

let deleteUserRes = http.del(`http://localhost:8080/api/v1/users/${userId}`);
let deleteUserRes = http.del(`http://brewbucks-485861802.us-east-1.elb.amazonaws.com/api/v1/users/${userId}`);

check(deleteUserRes, {
'user deletion status is 200': (r) => r.status === 200,
Expand Down
24 changes: 24 additions & 0 deletions report/report.tex
Original file line number Diff line number Diff line change
Expand Up @@ -359,6 +359,30 @@ \subsubsection*{Scalability}
\subsubsection*{Reliability}
With 100\% success rates in most critical operations, the system demonstrates high reliability. This is crucial for maintaining user trust and ensuring consistent service availability.

\subsubsection*{Security}
Summary of security considerations in bullet point form below. A more in-depth discussion is in the paragraph below.
\begin{itemize}
\item Role-based access control in form of employee and customer accounts
\item Principle of KISS for user logins and architecture
\begin{itemize}
\item Architecture has no redundant services, intentionally kept simple
\item Omit features where delivery wouldn't be done well, minimising security and design flaws
\end{itemize}
\item Principle of least privilege: customer account does basic ordering, employee account can modify menu items and order status
\item Dependency management for secure software
\begin{itemize}
\item Lock files give the benefit of preventing against dependency injection
\end{itemize}
\item Confidentiality design - masking used for disclosure protection when user enters their password
\item Plans for authentication of employee logins, left out due to time
\item Plans for monitoring and traceability
\item Never store sensitive customer information e.g., payment details
\end{itemize}

\medskip \noindent The Brewbucks application considers security design principles. Role-based access control has been adopted for users that interact with the application. Two roles have been created to service the users: customer and employee. Employees gain admin privileges by engaging with the administrator's page - a separate user interface. This principle ties with the next security design principle, KISS. The decision to have as few roles as possible helped to simplify access control. Similarly, the architecture and functionality was designed with simplicity in mind as a quality attribute, further supporting the security design principle. Some examples of this include pursuing a service-based architecture and not microservices and dropping the customisable ordering feature. For functionality, the idea was to avoid delivering features that, if not implemented well, could create security and design flaws. A feature that comes to mind is the customisable ordering. If not implemented well, it could be exploited by users. One other aspect to RBAC was the principle of least privilege. Customer accounts were only given privileges to do basic customer operations, such as browse the menu, purchase items. While employee accounts have the ability to create new menu items, edit customer order status etc. Authentication was planned for employee logins. This would have been implemented with npm package express-basic-auth. It would simply add data transfer from server to client to ensure credentials are correct

\medskip \noindent Brewbucks follows additional practices for secure software. Confidentiality design is followed, whereby masking is used for disclosure protection when a user enters their password. Dependency management is also followed. Lock files give the advantage of protecting against dependency injection. It was also intended for the system to log relevant operational information, such as events handled, packets processed and requests satisfied. This is useful for long term security purposes to diagnose breaches or attacks promptly.

\section{Evaluation}
Summarise testing results and justify how well the software achieves its quality attributes.
\section{Reflection}
Expand Down

0 comments on commit e46d80d

Please sign in to comment.