Initial commit

This commit is contained in:
2021-01-07 17:30:11 +01:00
commit 664f034751
29 changed files with 1229 additions and 0 deletions

72
README.md Normal file
View File

@@ -0,0 +1,72 @@
<h1>ConsoleTwitter</h1>
Implementation of a console-based social networking application (similar to Twitter) satisfying the scenarios below.
<h2>Scenarios</h2>
Posting: Alice can publish messages to a personal timeline
```
> Alice -> I love the weather today
> Bob -> Damn! We lost!
> Bob -> Good game though.
```
Reading: Bob can view Alices timeline
```
> Alice
I love the weather today (5 minutes ago)
> Bob
Good game though. (1 minute ago)
Damn! We lost! (2 minutes ago)
```
Following: Charlie can subscribe to Alices and Bobs timelines, and view an aggregated list of all subscriptions
```
> Charlie -> I'm in New York today! Anyone want to have a coffee?
> Charlie follows Alice
> Charlie wall
Charlie - I'm in New York today! Anyone want to have a coffee? (2 seconds ago)
Alice - I love the weather today (5 minutes ago)
> Charlie follows Bob
> Charlie wall
Charlie - I'm in New York today! Anyone wants to have a coffee? (15 seconds ago)
Bob - Good game though. (1 minute ago)
Bob - Damn! We lost! (2 minutes ago)
Alice - I love the weather today (5 minutes ago)
```
<h2>Details</h2>
* The application uses the console for input and output.
* Users submit commands to the application.
* There are four commands. “posting”, “reading”, etc. are not part of the commands.
* Commands always start with the users name.
* posting: user name -> message
* reading: user name
* following: user name follows another user
* wall: user name wall
<h2>How to run the application</h2>
* Clone the repository.
* Enter repository folder.
* Run the app with:
`.\gradlew run -q --console=plain` in Windows or
`./gradlew run -q --console=plain` in Linux.
* Alternatively you can also run from within the IDE:
Load the class `com.lookiero.ConsoleTwitter` and run the `main()` function.
* To stop the app, `press Ctrl + C`
<h2>Tests</h2>
A series of tests have been added with the following coverage:
![](src/main/resources/coverage.png)
To run the tests, execute `.\gradlew test` (`./gradlew test` in Linux)
Report is generated in `.\consoletwitter\build\reports\tests\test\index.html`