Skip to content

🖥 CRUD Angular + Spring demonstrating Has-Many relationship, including tests for the back-end and front-end

License

Notifications You must be signed in to change notification settings

adityalochan/crud-angular-spring

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

REST API with Spring Boot and Angular

Java Build Angular Build

CRUD Angular + Spring demonstrating Has-Many relationship, with tests.

This API is to showcase, specially for beginners, what a basic CRUD API that's close to be Production ready looks like.

💻 Tecnologies

  • Java 17
  • Spring Boot 3 (Spring 6)
  • JPA + Hibernate
  • JUnit 5 + Mockito (back-end tests)
  • Maven
  • Angular v16
  • Angular Material
  • Karma + Jasmine (front-end tests)

⌨️ Editor / IDE

  • Visual Studio Code
  • Java Extensions link
  • Angular Extensions link

Some functionalies available in the API

  • ✅ Java model class with validation
  • ✅ JPA repository
  • ✅ JPA Pagination
  • ✅ Controller, Service and Repository layers
  • ✅ Has-Many relationship (Course-Lessons)
  • ✅ Java 17 Records as DTO (Data Transfer Object)
  • ✅ Hibernate / Jakarta Validation
  • ✅ Unit tests for all layers (repository, service, controller)
  • ✅ Test coverage for tests
  • ✅ Spring Docs - Swagger (https://springdoc.org/v2/)

Not implemented (maybe in a future version)

  • Security (Authorization and Authentication)
  • Caching
  • Data Compression
  • Throttling e Rate-limiting
  • Profiling the app

Some functionalies available in the Front-end

  • ✅ Angular Material components
  • ✅ List of all courses
  • ✅ Form to update/create courses with lessons (has-many - FormArray)
  • Form async validation for duplicated courses and lessons
  • View only screen
  • ✅ TypedForms (Angular v14+)
  • ✅ Presentational x Smart Components
  • [In Progress] Unit and Integration tests for components, services, pipes, guards

❗️Executing the code locally

Executing the back-end

You need to have Java and Maven installed and configured locally.

Open the crud-spring project in your favorite IDE as a Maven project and execute it as Spring Boot application.

Executing the front-end

You need to have Node.js / NPM installed locally.

  1. Install all the required depencencies:
npm install
  1. Execute the project:
npm run start

This command will run the Angular project with a proxy to the Java server, without requiring CORS.

Open your browser and access http://localhost:4200 (Angular default port).

About

🖥 CRUD Angular + Spring demonstrating Has-Many relationship, including tests for the back-end and front-end

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 48.1%
  • TypeScript 45.0%
  • HTML 4.8%
  • SCSS 2.0%
  • JavaScript 0.1%