Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Demo: Testing frameworks for JavaScript in frontend and backend #1594

Merged
merged 2 commits into from
Mar 26, 2022
Merged

Demo: Testing frameworks for JavaScript in frontend and backend #1594

merged 2 commits into from
Mar 26, 2022

Conversation

elibon99
Copy link

@elibon99 elibon99 commented Mar 25, 2022

Assignment Proposal

Title

Testing frameworks for JavaScript in frontend and backend

Names and KTH ID

Deadline

Task 1

Category

Demo

Description

With the NodeJS ecosystem, JavaScript can be used in both frontend and backend. As with any software stack, unit and integration testing are an essential part, yet selecting the right tool for each individual use case can be a challenge, as NodeJS-based environments can be highly diverse.

In this demonstration, we show how JavaScript-/NodeJS-based frontends and backends can be tested in real life and how to set up and run such tests with the respective frameworks. Specifically, we will demonstrate the combined use of Jest and Supertest for the backend and its HTTP routes and React Testing Library for the frontend.

@dd2482-bot
Copy link
Collaborator

Readme is not correctly formatted
Need exactly: ['Assignment Proposal', 'Title', 'Names and KTH ID', 'Deadline', 'Category', 'Description']

Got: ['Demo Proposal', 'Title', 'Members', 'Deadline', 'Category', 'Proposal']

@javierron javierron self-assigned this Mar 25, 2022
@javierron javierron added proposal A task proposal demo One of the task categories listed in README.md labels Mar 25, 2022
@javierron
Copy link
Collaborator

Hello @elibon99, thanks for the proposal.

Could you list on the description which JS frontends and backends you will be focusing on? There has been some work done previously on this course about Express and React. It would be great to perform your demo on environments different than these.

@sigalor
Copy link

sigalor commented Mar 25, 2022

Hey @javierron, please refer to the email I just sent you with my phone number so that we can quickly discuss this issue.

@javierron
Copy link
Collaborator

javierron commented Mar 25, 2022

Hello @sigalor, thanks for your reply.

If you prefer real-time interaction, we are happy to discuss during the breaks in the lectures, or during a lab session.
(IMO It is much better if any discussion regarding the task is documented here, as we would be able to refer to it at a later time.)

In any case, the task you have described is very relevant to this course, but it is necessary that the description is updated to be clearer before the task is accepted.

@sigalor
Copy link

sigalor commented Mar 26, 2022

@javierron So the situation is that we agreed with the professors that we would do this demonstration during the next lecture slot, i.e. on March 29th. Until then, we don't have any other lab sessions, meaning that there is no way to discuss this in person, Let me outline the points I discussed with Elias here then instead.

Firstly, as you already mentioned, NodeJS, React and Express are highly relevant frameworks in today's software development world, so we are convinced that our demonstration with these two frameworks specifically would be highly valuable to the other students. After all, even if students in past semesters did some assignments on these, that doesn't really matter for us now, because the students that take the DevOps course for the first time right now should also have the opportunity to learn this.

Furthermore, the NodeJS ecosystem evolves very rapidly. For instance, Enzyme is a testing framework for React which hasn't been updated for two years by now, meaning that it is essentially deprecated by now. A year ago, this might not have been so relevant yet, but now the situation has changed. In our opinion, shortly discussing these "meta topics" like realizing how your software stack is constantly evolving and has to be updated dynamically is also an essential part of good, long-lasting software engineering. With these examples in very common environments like React, we could illustrate this very clearly.

Regarding our own knowledge, Elias and I are already fairly familiar with React, Express and the foundation of NodeJS. We also see this demo of testing frameworks as an invitation for the audience (i.e. the other students) to ask us questions about these frameworks, which we will probably be able to answer quite confidently given our existing experience. On the other hand, if we would demonstrate testing libraries in some other framework (e.g. Vue or Angular for the frontend or something like Koa for the backend), we would mostly be learners ourselves, so that we would be much less able to help other students if they ask us about something specific and technical. Consequently, we think that staying with React and Express would be much more valuable for the audience for this reason as well.

Apart from that, as I also mentioned in the lecture last Tuesday when I proposed this topic, Elias and I are still very interested in learning about testing frameworks for JS in the frontend and backend ourselves. As the professors emphasized, this course should be a combination of us learning new things when doing the assignments and sharing knowledge with the other students. The former would be especially fulfilled when focusing on React and Express in the demo, because Elias and I as well as Per and Philip (see next paragraph) are both personally and professionally interested in these frameworks specifically.

During the lecture last Tuesday, the professors suggested that we should form a four-person group for the topic of JS testing frameworks, where two people do a presentation (Per and Philip, see #1593) and the other two a demo (Elias and I). Of course we are fully aware of the fact that regarding the grading, presentation and demo are two fully separate things and each one should be standalone. But we still think that from the audience's point of view, it would be a much more useful narrative when Per and Philip first present some "theory" for possible testing frameworks and compare several different ones and then Elias and I show two of them in a real-life scenario, for the frontend and backend respectively. Thus, if for this demo, we would have to pivot to other frameworks instead of React with React Testing Library and Express with Jest and Supertest, this narrative would be broken. This would of course not be terrible, because the demo is still standalone, but for the audience, some interesting and valuable context might be lost.

Finally, from an organizational point of view, we of course have time pressure right now. As suggested by the professors, the presentation from #1593 and our demo will be held on Tuesday, March 29th. During the lab session yesterday, Deepika (@Deee92) verbally approved our proposal descriptions, so we already started working on the demo, thinking that having this pull request merged would only be a small formality.

We'd be very grateful if either you, Martin (@monperrus) or Benoit (@bbaudry) could give us feedback on how to proceed with this. Right now, we see three options:

  1. We stay with React and Express for the demo, due to the arguments above and so that it is perfectly aligned with the corresponding presentation. If you agree with this and would just like the proposal description to be a bit more elaborate, kindly hint us towards which changes are necessary specifically.
  2. We have to switch to other frameworks instead of React and Express, which would have its drawbacks also outlined above.
  3. In case we cannot come to an agreement or in case you think that regarding the grading formalities, there is no way how we could pass this demo assignment (e.g. because similar demos have been done before or just because the topic of JS testing is too common altogether), we would have to discard this entire proposal. That would of course be the most unfortunate option and a lose-lose situation for everyone.

As this demo should take place next Tuesday morning, it isn't really feasible for us to wait until Monday to be sure that we can fully prepare the demo. As mentioned, it would thus be great if we could get your feedback as soon as possible. In case we don't get any feedback until tomorrow (Sunday) at noon, Elias and I will assume to go with option 1 and prepare the demo as planned in order to present it on Tuesday.

@javierron
Copy link
Collaborator

Thanks for the detailed response, it's super clear now.

I look forward to seeing your demo.

@javierron javierron merged commit b6f9fdb into KTH:2022 Mar 26, 2022
@nalenz
Copy link

nalenz commented Mar 29, 2022

The two repositorys showed in this demo today can be found here:

@monperrus
Copy link
Member

@elibon99 @sigalor could you update your readme with a link to the demo repo (more durable than a comment)? Thanks!

@nalenz
Copy link

nalenz commented Mar 29, 2022

@monperrus Of course, please find the respective PR at #1625!

Eyskha added a commit to Eyskha/devops-course that referenced this pull request Apr 6, 2022
* Executable tutorial: How to automate E2E-testing in React & Jest, using Github actions. (KTH#1589)

* Project proposal for Executable tutorial

* fix: renamed itle

* doc: Add readme for the task (KTH#1591)

* Added README.md for Project Proposal (KTH#1588)

* Added README.md for Project Proposal (KTH#1590)

Co-authored-by: Johanna Loev <[email protected]>

* Presentation Proposal: Optimization Strategies for Test Suite Runtimes in Large Software Applications (KTH#1573)

* Project proposal

* Project proposal

* Move readme to correct location

* Rename proposal dir

* Rename proposal dir

* Rename proposal dir

* Small format change

* Small format change

* Small format change

* Small format change

Co-authored-by: Luke LeVasseur <[email protected]>

* Presentation Proposal: gatien-myechui (KTH#1597)

* Executable Tutotial: Adding bugs to code to evaluate tests Using Stryker Mutator in JS (KTH#1575)

* feat: test

* feat: first proporsal

* feat: first proporsal

* demo proposal: Automated embedded testing of FreeRTOS using Jenkins and AWS (KTH#1578)

* assignment proposal: demonstration for week1: testing & continuous integration

* Rename markdown file

* not ignoring cases anymore

* fix titles

* Delete Readme.md

* put proposal inside week folder

* fix schema

* Update README.md

* Update README.md

* Open source proposal: enhancement of embedded Rust libraries (testing) (KTH#1587)

* open source proposal: embedded rust libraries

* changed email email

* added missing assignment

* Demo proposal - Real-Time testing of a video game (KTH#1581)

* Add README for demo

* moved the readme

* fixed readme

* Demo: Testing frameworks for JavaScript in frontend and backend (KTH#1594)

* added our demo proposal

* modified demo proposal

* Weekly schedules

We'll update the schedule for presentations and demos here

* Update sessions on bots and dependencies

* update the script based on the new folder structure

* action: update the target branch name (KTH#1609)

* added README describing our presentation proposal (KTH#1593)

* added README describing our presentation proposal

* updated readme to fit the expected format

* Update week 2 agenda

* Update demo + presentation weeks

* First proposal for course automation (KTH#1579)

* Add proposal for course automation task (KTH#1586)

* Add proposal for course automation task

* Rework proposal

* Slight modification

* Update README.md

Co-authored-by: Khashayar Etemadi <[email protected]>

* Essay proposal: CI comparison (KTH#1598)

* docs: add README for proposal (KTH#1603)

* executable-tutorial: proposal GH Action optimization (KTH#1572)

* executable-tutorial: proposal GH Action optimization

* fix: formatting of README.md

* Update readme.md

* Update readme.md

* Presentation proposal - Facebook blackout (KTH#1592)

* added our presentation proposal

* added presentation

* Rename contributions/presentation/README.md to contributions/presentation/week2-testing-and-CI/svanhol-libl/README.md

Co-authored-by: vladomitrovic <[email protected]>

* Update readme.md

* Presentation proposal - Code Coverage (KTH#1582)

* Added a presentation proposal for code coverage.

* Correct folder

* Changed readme to comply with necessary formatting.

* Reformulated our proposal to be more specific.

Co-authored-by: vladomitrovic <[email protected]>

* Update week 2 agenda

* Update readme.md

* Update README.md

* Presentation : robot framework and end user test (KTH#1611)

* Delete README.md

* Update readme.md

* Delete README.md

* Added demo proposal (KTH#1614)

Co-authored-by: Preston Chao <[email protected]>

* Create README.md (KTH#1612)

* Create Proposal for presentation: deployment of code with Buddy (KTH#1604)

* Create Proposal for presentation: deployment of code with Buddy

* Rename contributions/presentation/week3-CD-and-feature-flag/lhagm-shotaro/Proposal for presentation: deployment of code with Buddy to contributions/presentation/week3-CD-and-feature-flag/lhagm-shotaro: README.md

* Update lhagm-shotaro: README.md

* DEMO Proposal: Eiffel Protocol demonstration of usage (KTH#1610)

* Update README.md

* moved proposal to correct space

* added slides used in the presentation and a link to them (if needed) in the README. (KTH#1621)

* Presentation Proposal Update: Add link to slides (KTH#1613)

* link to slides

* format

* ugh format

Co-authored-by: Luke LeVasseur <[email protected]>

* Final submission: Presentation (gatien-myechui) (KTH#1620)

* unregistere user removed from foldername

* unregistered user removed from the readme

* Update and rename readme.md to README.md

* Update README.md

* Demo proposal : Continuous Delivery of a Tauri app (KTH#1628)

* Added task 1 proposal

* Fixed typo

* Updated folder name

* Added demo proposal

* Fixed email address

* Fixed typos

* Course automation proposal - Automatic labeling of PRs (KTH#1608)

* add proposal for course automation task

* add new proposal

* align demo length with presentation length (KTH#1618)

* course-automation: Automatic verification for mandatory parts of course-automation final (KTH#1629)

* docs: 📝 task: course-automation complete

* Update README.md

* Update README.md

* Update README.md

* Update README.md

* Update README.md

* Update README.md

* Update README.md

* Update README.md

* Update README.md

* Update README.md

* Adds proposal for course automation task. (KTH#1606)

Adds proposal for a course automation task that would automatically fetch calendar events for the course to display in a file of choice.

* Add slides week 1 presentation slides (KTH#1640)

* Presentation proposal : Robot framework


Assignment Proposal
Robot framework and user test 


Names and KTH ID

    Pauline Vaillant ([email protected])
    Asim Jarrar ([email protected])

Deadline

Task 1
Category
Presentation


Description
Presentation of robot framework

* Change readme place

* Delete paulinev-asmi

* Create readme

* Correction file name

* Delete typo directory

* Correct typo 2

* Delete paulinev-asim

* Create readme.md

* Remove wrong typo directory

* Update readme.md

* Add presentation slide

* Add presentation slides

* Delete useless directory

* Demo proposal: Demonstration of continuous deployment using Bitbucket Pipes (KTH#1641)

* Create proposal template

* Update readme.md

* Added task proposal

* Fixed kth name

* fix readme

* Finished Executable Tutorial - Build automation with Maven and Selenium to maintain test automation  (KTH#1632)

* Added README.md for Project Proposal

* Added grading information for the executable tutorial

* cleaning

* executed tutorial: Github Action CI pipeline using CodeQL for static code scanning (DevSecOps Application) (KTH#1616)

* Adding Assignment proposal

* Update README.md

Adding links to our GitHub handles

* Update README.md

Edit description

* Update README.md

Removing Github handles as it crashes the script

* Updating folder name

* Add repository links of "Testing frameworks for JavaScript in frontend and backend" demo to respective readme (KTH#1625)

* ADD tutorial proposal for Randoop (KTH#1648)

* added readme for demo proposal (KTH#1642)

* Presentation Proposal: An overview of continuous deployment in the Microsoft Azure environment (KTH#1644)

* Create README.md

* Update README.md

* Update README.md

* Added readme for presentation proposal (KTH#1637)

* presentation: Serverless in a hybrid architecture (KTH#1615)

* Adding initial proposal

* Fixing folder name

* Added readme for tutorial (KTH#1627)

* executable tutorial (KTH#1643)

* demo proposal for argocd (KTH#1649)

* Course Automation: Enforcing course submission rules (KTH#1650)

* civjan-palagi course automation proposal

* Update README.md

Co-authored-by: Khashayar Etemadi <[email protected]>

* demo proposal: CD using React Native and Google Cloud (KTH#1635)

Co-authored-by: Filip Bäck <[email protected]>

* Course Automation Proposal: Make Pull Request shell script (KTH#1645)

* add proposal for mpr shell script

* update readme

* update

Co-authored-by: Luke LeVasseur <[email protected]>

* Essay proposal - Continuous deployment - How does feature toggle fit in? (KTH#1630)

* Demo proposal: CD of a Node.js web service on Heroku with a Github Actions pipeline (KTH#1636)

* Create demo proposal readme

* Update README.md

* Update README.md

* Update README.md

Co-authored-by: Khashayar Etemadi <[email protected]>

* Presentation proposal: Canary Deployment - Why you and your friends might have different versions of the same app (KTH#1623)

* Added README for presentation for week three

* Blank line for PR update

Now that the asim not registered problem is fixed

* Added presentation in Category

Co-authored-by: tobiasgg <[email protected]>

* Add files via upload (KTH#1653)

* Proposal Executable Tutorial: Test automation using Cucumber with Gradle (KTH#1658)

* WIP: program of week 3 (KTH#1647)

* Update readme.md

* Update readme.md

* Update week 4 presentation/demo schedule (KTH#1672)

Co-authored-by: Khashayar Etemadi <[email protected]>

* Create README.md (KTH#1651)

* Update readme.md (KTH#1676)

* Update readme.md

* Delete README.md

* Update readme.md

* Update required number of words for essays check

* Essay: Gitlab CI vs Github Actions (KTH#1688)

* Presentation Proposal: Handling multiple services in a monorepo using Docker (KTH#1677)

Co-authored-by: Luciano <[email protected]>

* Update readme.md

* Course Automation: Implementation of MPR shell script (KTH#1654)

* initial script

* MPR functionality working

* Clean up

* Update alias in help

* Clean Up

* Small change for demo

* Small change for demo

* Auto-fill description body with readme contents

* Update description logic

* Update description logic

* Tweaks

* Only use GH Username if user not populated

* Tweak

* Add link to readme for submission

* Remove script from submission

Co-authored-by: Luke LeVasseur <[email protected]>

* Proposal: Contribution to open-source (KTH#1721)

* Add completed demo branch (KTH#1719)

* Create demo proposal readme

* Update README.md

* Update README.md

* Update README.md

* Add demo repo link

* Remove unnecessary section

Co-authored-by: Khashayar Etemadi <[email protected]>

* Tutorial proposal: Massively cutting server costs for model training with spot instances on Azure (KTH#1718)

* Add proposal for course automation task

* Rework proposal

* Slight modification

* Update README.md

* Add essay proposal

* Add Khalid to proposal

* Delete README.md

Co-authored-by: Khashayar Etemadi <[email protected]>
Co-authored-by: César Soto Valero <[email protected]>

* Submission : Demonstration of Continuous Deployment of a Tauri app (KTH#1717)

* Updated readme for submission

* Fixed some typos

* Fixed README

* Final Submission for Task 1 (KTH#1715)

* demo proposal for argocd

* Submission for Task 1

* Update README.md

* update submission git link

* Update README.md

* Update README.md

* Final submission - Github Action CI pipeline using CodeQL for static code scanning (DevSecOps Application) (KTH#1714)

* Adding Assignment proposal

* Update README.md

Adding links to our GitHub handles

* Update README.md

Edit description

* Update README.md

Removing Github handles as it crashes the script

* Updating folder name

* Adding assignment description

* Final Submission: Docker swarm executable tutorial (KTH#1709)

* docs: add README for proposal

* Final submission: exec tutorial

* Final Submission for Task 1 - CI/CD pipeline for K8s Cluster in Digital Ocean for Microservices application. (KTH#1701)

* added readme for demo proposal

* Submission for Task 1

Co-authored-by: César Soto Valero <[email protected]>

* Final Submission: Fuzzing Executable Tutorial (KTH#1705)

* Proposal for OSS-Fuzz executable tutorial

* final submission README

* working on final submission

* marked easter-egg

Co-authored-by: Palagi, Brad <[email protected]>

* Finished E2E testing with React executable tutorial (KTH#1699)

* Final Submission: Deployment of Ccde Using Buddy (KTH#1697)

* Adds Assignment Proposal (KTH#1689)

Co-authored-by: Pontus Cowling Mantefors <[email protected]>

* Added demo repo & key takeaway (KTH#1702)

* Create proposal template

* Update readme.md

* Added task proposal

* Fixed kth name

* fix readme

* Add bitbucket repo link

* Submission: Essay: DevOps and Security - How to fit them together? (KTH#1706)

* Create README.md

* Create DevSecOps.pdf

* Updated to pass word count

* Less word count

* Update DevOps_and_Security - How_to_fit_them_together.pdf

* Created final submission for civjan-palagi course automation (KTH#1704)

* Mockito Presentation (KTH#1595)

* Update README.md

* Update README.md

* Rename contributions/presentation/README.md to contributions/presentation/week2-testing-and-CI/ddnadjar/README.md

* Update README.md

Co-authored-by: Khashayar Etemadi <[email protected]>
Co-authored-by: vladomitrovic <[email protected]>

* Final Submission: Executable Tutorial (KTH#1692)

* executable-tutorial: proposal GH Action optimization

* fix: formatting of README.md

* [ Final Submission ] executable tutorial

* fix: assignment and README seperation

* fix: added links

* fix: put links in proposal README

* fix: removed header to pass action

Co-authored-by: lucianozapata <[email protected]>
Co-authored-by: isabelredtzer <[email protected]>
Co-authored-by: joloev <[email protected]>
Co-authored-by: Johanna Loev <[email protected]>
Co-authored-by: Luke LeVasseur <[email protected]>
Co-authored-by: Luke LeVasseur <[email protected]>
Co-authored-by: EDChui <[email protected]>
Co-authored-by: Diego Chahuan <[email protected]>
Co-authored-by: Fabian Segatz <[email protected]>
Co-authored-by: vladomitrovic <[email protected]>
Co-authored-by: Aïssata Maiga <[email protected]>
Co-authored-by: lnsandnkth <[email protected]>
Co-authored-by: elibon99 <[email protected]>
Co-authored-by: Benoit Baudry <[email protected]>
Co-authored-by: gluckzhang <[email protected]>
Co-authored-by: Per Arn <[email protected]>
Co-authored-by: Deepika Tiwari <[email protected]>
Co-authored-by: Philip Hamelink <[email protected]>
Co-authored-by: Neproxx <[email protected]>
Co-authored-by: Khashayar Etemadi <[email protected]>
Co-authored-by: Niko <[email protected]>
Co-authored-by: Joakim Olsson <[email protected]>
Co-authored-by: Arvid Gotthard <[email protected]>
Co-authored-by: Fredrik Svanholm <[email protected]>
Co-authored-by: vladomitrovic <[email protected]>
Co-authored-by: Max Persson <[email protected]>
Co-authored-by: paulinev-kth <[email protected]>
Co-authored-by: Martin Monperrus <[email protected]>
Co-authored-by: pdchao23 <[email protected]>
Co-authored-by: Preston Chao <[email protected]>
Co-authored-by: Zehao Jiang <[email protected]>
Co-authored-by: Linnea55 <[email protected]>
Co-authored-by: LukasGutenberg <[email protected]>
Co-authored-by: corentinguilloteau <[email protected]>
Co-authored-by: Daniel Gustafsson <[email protected]>
Co-authored-by: John Landeholt <[email protected]>
Co-authored-by: Johan Edman <[email protected]>
Co-authored-by: Abyel Tesfay <[email protected]>
Co-authored-by: Bassam Gamal <[email protected]>
Co-authored-by: nalenz <[email protected]>
Co-authored-by: Mustafa Ali <[email protected]>
Co-authored-by: Abdullah <[email protected]>
Co-authored-by: Noah Rahimzadagan <[email protected]>
Co-authored-by: sandy-e <[email protected]>
Co-authored-by: FilipSannervik <[email protected]>
Co-authored-by: Ayushman Khazanchi <[email protected]>
Co-authored-by: Ben Civjan <[email protected]>
Co-authored-by: Filip Bäck <[email protected]>
Co-authored-by: Filip Bäck <[email protected]>
Co-authored-by: persman96 <[email protected]>
Co-authored-by: Nick Smyrnioudis <[email protected]>
Co-authored-by: Samuel Söderberg <[email protected]>
Co-authored-by: tobiasgg <[email protected]>
Co-authored-by: gogo432754 <[email protected]>
Co-authored-by: shotaroi <[email protected]>
Co-authored-by: Javier Ron Arteaga <[email protected]>
Co-authored-by: simonebonato <[email protected]>
Co-authored-by: Bror Sebastian Sjövald <[email protected]>
Co-authored-by: Luciano <[email protected]>
Co-authored-by: César Soto Valero <[email protected]>
Co-authored-by: Brad Palagi <[email protected]>
Co-authored-by: Palagi, Brad <[email protected]>
Co-authored-by: Pontus Mantefors <[email protected]>
Co-authored-by: Pontus Cowling Mantefors <[email protected]>
Co-authored-by: mindany2 <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
demo One of the task categories listed in README.md proposal A task proposal
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants