After a year of work on various facets of CMC's tech landscape as a consultant, I was permanently hired as Principal Software Engineer.
Within the Onboarding squad, while continuing my previous duties, I've also been pushing to migrate away from a legacy Java monolith towards an AWS lambda based approach, in line with company strategy. This effort was designed to create a distributed, modern backend setup to implement sign-up functionalities.
I would consistently advocate XP specific practices like:
- Relying on code quality tools like SonarQube or various linters
- TDD (think tools like Jest, JUnit)
- BDD, to ensure specific scenarios were implemented as necessary from a business perspective (using Cypress, Cucumber)
- CI/CD, so that every delivered batch of code was up to par with what was expected of it (I've used GitHub workflows and Jenkins for that)
- Frequent code checkins, to minimise friction between parallel streams of work
- Gathering feedback from stakeholders to ensure a correct trajectory of what was being built
Staying abreast requirements often meant delving into legacy Java services, extending them in an environment where an asynchronous, message based architecture was at the heart of a company-wide architecture. The stack consisted of:
- Spring
- ActiveMQ
- Oracle SQL
- Protobuf
- RxJava