COMP3111: Software Engineering Project - Webscrapper
Project Problem Statement and Activities
Activity 1 Due (20%): 15-10-2018 (Wk 7 Mon) 23:59
Submission details will be provided on Canvas
Activity 2 Due (30%): 19-11-2018 (Wk 12 Mon) 23:59 30-11-2018 (Wk 13 Fri) 23:59
Submission details will be provided at Canvas
Introduction
You are going to form a team of three to work on a project. The project is about web scraping - obtaining and analysis data
from some websites automatically. You are given a skeleton code written in Java 8 that is already able to use a keyword to
fetch some data from Craiglist. Please try the demo program to have a better idea of what the skeleton code can
do. You need Java 8 JDK to run and develop it. At the end of the file there is a guide to compile the project.
System Requirements
There are two sets of System Requirements: Basic Tasks and Advanced Tasks. Each student should complete TWO tasks.
Each COMP3111H must pick one from the Advanced Tasks while it is optional to COMP3111 student to pick both tasks from Basic
Tasks or having one from the Advanced Tasks. Each task, regardless it is basic or advanced, carries 20 points for
full marks which will be converted to 8 points of your course total.
Noted that the some tasks are in a hierarchy structure. No point will be awarded if the parent task is not completed.
Points are given in all-or-nothing fashion.
Basic Tasks (20 points or 8% of course total.)
- Fill in the tab
Summary
- Correctly filled the tab. #1 [5]
- Refresh contents on another search. [5]
- Put "-" to Average selling price, lowest selling price and latest post for result not found. [3]
- Put a clickable URL in the field Lowest Selling Price and Latest Post.[3]
- Pop up a windows/browser showing that item.[4]
- Be able to scrape data from a single webpage of a local/international selling/reselling portals (e.g. carousell, dcfever, preloveled, taobao or any similar webpage. Please noted that we only accept websites written in English or Chinese) Note, there is no requirement to handle multiple pages data.
- Print the scraped data in the console tab [6]
- Modify the class Item so that it will also record which portal this item is coming from. [5]
- The returned result of the function WebScraper.scrape contains the merged data from two portals. [5]
- The returned result is sorted by price. If two items have the same price, item sold on Craiglist go first. If two items from the same portal has the same price, they can be sorted in any order.[4]
- Handle pagination
- scrape data from more than one pages if the search contains more than one pages of results.[12]
- Correctly determine the last page of the search and scrape data from all available pages.[4]
- Write to the
Console
tab and show how many pages has already been scraped during the process. So that the user would aware the program is still running. (Note: asychronized I/O is not required.) [4]
- Fill in the tab
Table
with all result of the current search.
- Correctly filled the result. [4]
- Sort the result in ascending order on user clicking each column, and sort in descending order when user click again. [4]
- Make all cells in the table not editable. [4]
- Pop up a new windows/browser showing the item when the
URL
is clicked. [4]
- Refresh the table on another search. [4]
- Refine search.
- Create an extra button that shows
Refine
just below the Go
button with at least 5px of space. Make this button right align the Go
button.[3]
- when the refine button is clicked, filter the searched data and keep those items with their titles containing the keywords typed in the text area.[5]
- Update all tabs on the right. (Note: the correctness of the info of the tabs may depend on other features. This requirement needs only to trigger the update process.) [4]
- Make the button
Refine
disabled (grey) before any keyword is being searched, or after Refine
is clicked once.[4]
- Make the button
Refine
enabled after a new search ( e.g. Go
button is clicked).[4]
- Finish the rest of the menu bar except
Save
and Open
- Make
About your Team
showing a new simple dialog that shows all your team members name, itsc account, and github account.[3]
- Make
Quit
button exiting the program and close all connections.[3]
Close
will clear the current search record and initialize all tabs on the right to their initial state.[5]
New (call Controller.actionNew())
should be renamed to Last Search
and revert your search result to the previous search.[5]
- Before any keyword is being searched, or after
Last Search
is clicked once, it should be disabled (gray and unable to be clicked).[2]
Last Search
will be enabled after a new search ((Go
) button is clicked).[2]
Advanced Tasks (Each H course student is required to implement one of these tasks. 20 points or 8% of course total.)
- Complete the Distribution tab.
- Fill the price histogram with 10 equal width bins. The range of the bins should be determined by the price range of the search product. The first bin should contain the lowest price while the last bin should contain highest price. [2.5]
- The histogram has proper X-axis label, Y-axis label, legend which says
The selling prize of SEARCH_KEYWORD
The selling price of SEARCH_KEYWORD
.[2.5]
- The histogram is able to refresh (including the axis) on another search.[2.5]
- Leave the histogram empty if not result is found.[2.5]
- If there is only one price of the histogram, just have one bar in the chart.[2.5]
- Create an event to handle double-click on a particular bar of the histogram.[2.5]
- The console screen will be cleared and display those items with the price falling in this bar (in the default format).[2.5]
- The bar being double clicked will change its color and the rest of the bars should restore its color to default. [2.5]
- Save and load your search - A search record can be saved into a file (no requirement on the file format). When the program restarts and the saved file is loaded, it will be able to reconstruct the same List of search result
List<Item>
.
- Implement the save function using the button
save
.
- When open the file using a text editor, it will able to see data are correctly stored. [2.5]
- Open a dialog box (any type of dialog box) that allow you to type your filename with a pre-defined file extension. (Name any file extension you want)[2.5]
- When an existed file is chosen for save, dialog box is prompted to warn the user he is about to overwrite a file.[2.5]
- Implement the load function using the button
open
- Able to correctly load the data. [2.5]
- the content of the items and the order of the item will be preserved.[2.5]
- Open a FileChooser
javafx.stage.FileChooser
that allows user to pick the file.[2.5]
- The FileChooser has a file extension filter. (e.g. display only file ended with .dat if .dat is your pre-defined file extension)[2.5]
- After the data is load, the console will be cleared. The sentence
--Data Loading from FILE_NAME--
will be written to the console followed by the data loaded from the file in correct order.[2.5]
- Finish the
Trend
tab so that it shows the average price of a particular search of products changing over last 7 days.
- The chart should be a line chart that contains 7 points. Each point denotes the average price of the products of the searched keyword those are posted on that day.[2.5]
- When no data is available on a day the chart will draw one less point. [2.5]
- Update the Search Record combo box that displays the keyword of the last five searched keywords.[2.5]
- On select any of the search record and update the histogram instantly. [2.5]
- The chart has proper X-axis label (Date in mm/dd/yyyy format), Y-axis label, legend which says
The average selling prize of the SEARCH_KEYWORD
The average selling price of the SEARCH_KEYWORD
.[2.5]
- Create an event to handle double-click on a particular point of the chart.[2.5]
- The console screen will be cleared and display those items posted on that day.[2.5]
- The point being double-click will change its color and the rest of the points should restore its color to default.[2.5]
Technical Requirement
- The program must use Java 8.
- The project must use Gradle to manage.
- The program must use JavaFX as its only GUI framework. No Swing or AWT should be allowed.
- You may choose your own IDE. We recommend Eclipse IDE.
- JUnit 4.12 as your testing suite
- Jacoco as your test coverage measurement
- A Private GitHub repository for source control
- students can apply for GitHub Education to enjoy the benefits of creating unlimited private repositories at GitHub
- In your private repository setting page, add your team members and all our TAs as collaborators.
Team Requirements
- Cross-section team forming is allowed (i.e. L1 students can form a team with H students)
- A COMP3111H student will still need to do an advanced task in any case.
- Each team MUST be formed by 3 students enrolled in COMP3111 or COMP3111H.
- Team of 1/2/4/5/6/.. is never allowed.
- The teaching team will randomly assign the ungrouped students. Mathematically we might have one or two group of four.
- Each team member is expected to implement 2 features from the system requirements.
- A COMP3111H student needs to do ONE advanced task and ONE basic task.
- A COMP3111 student may opt to do TWO basic tasks or ONE advanced task plus ONE basic task.
- No two students in the same group can implement the same task. Students are expected to divide the workload by themselves.
- The member implementing the task is also required to manage the Git commit log messages, testing, debugging, and documentation of the task.
- Two developers may need to work on the same Java method concurrently. Team discussion meetings and version control using Git are essential to minimize conflicts during the software development process.
Activities to submit
Activity 1 - System Requirement Specification (15%)
Based on the above project requirements, prepare and submit
- A UML class diagram (6%)
- A use-case diagram (6%)
- The workload distribution among your team (2%)
- A github link properly setup (visible to TA) (1%)
Activity 2 - Software Implementation and Testing (25%)
- Team work
- A running program and the source code. (8% for each completed task, total 16% for a student)
- A README file stating the name of team members and their tasks assigned.
- Individual work - Even if you are failed to implement all tasks, the unit testing and coverage report are still required.
- Unit testing of your implemented tasks. (100% pass - 2%; 0% otherwise)
- Coverage test (>70% branch coverage- 2% ; 50-70% branch coverage - 1%; 0% otherwise)
- Git commit log at GitHub
- 3 "non-trivial" commits (1%)
- At least one "non-trivial" pull request (1%)
- Documenting your implemented features using JavaDoc (Full mark 1%: -0.25% for each missing argument, return value, exception, class description)
- If a function is responsible by more than one student, all of them will receive the penalty.
- At least 3 meeting minutes. (1%) (submitted at the end of this course)
- A Gantt chart (1%)
We expect most of the students will finish the project with reasonable efforts. They will most likely receive full marks.
- No bonus.
- No late submit.
Additional Notes (added 8/11/2018)
- Testing on JavaFX may require additional framework and that is not required. However, if you have done it, it would be counted toward your coverage test. You can also opt to exclude them in calculating the coverage. Please state your re-calculation in your READM.md if you choose to exclude.
- Check the Issue page for and FAQ questions.
Webscraper
Compile
We configure the project with Gradle. Gradle can be considered as Makefile like tools that streamline the compilation for you. In this project you
are not required to learn how to write Gradle file. If you are interested to know how, please check out this link.
Compile with Windows Command Prompt
Goto your folder and type gradlew run
. This will build and run the project.
If you want to just rerun the project without rebuilding it, you can go to the folder build\jar\
there should be a jar file (e.g. webscraper-0.1.0.jar
). Try double click on it
(yes, you need a GUI screen to run it).
Compile with Mac/Linux terminal
Goto your folder and type ./gradlew build
. This will build and run the project.
If you want to just rerun the project without rebuilding it, you can go to the folder build/jar/
there should be a jar file (e.g. webscraper-0.1.0.jar
). Try double click on it
(yes, you need a GUI screen to run it).
Compile with Eclipse
You are recommended to download the Eclipse Photon for Windows.
This version of eclipse supports Gradle out of the box. Create a new project
> Gradle Project
and drag
everything from the given base code to the project. Refer to Lab 1 to bring up the Gradle Tasks
windows and double
click on the application
> run
to launch the application.