-
Notifications
You must be signed in to change notification settings - Fork 236
How to Contribute to EdgeCloudSim
EdgeCloudSim is an open source project, so every contributor is welcome! EdgeCloudSim has not been fully tested regarding to many different scenarios. There may be some bugs which are waiting to be fixed. You can add new features on EdgeCloudSim such as:
Integration of different access technologies such as 3G/4G Adding a realistic energy consumption model for mobile devices as well as data centers Adding a realistic cost model for data centers Implementing task migration among VMs or Data Centers And more...
You can simply follow below steps to contribute to EdgeClouldSim:
- Create a working copy (fork the project & clone it)
- Specify a new remote upstream repository
- Push your modification to the origin repository
- Create a new pull request
Detailed explanation of the steps are given below:
Open https://github.com/CagataySonmez/EdgeCloudSim on your browser and press the "fork" button to create a copy of the repository in your own GitHub account. Then find forked EdgeCloudSim project in your GitHub account and copy the url for cloning. Finally clone this project by using 'git clone' command:
$ git clone https://github.com/YOUR_USERNAME/EdgeCloudSim.git
In order to sync the a forked repository with the original repository, you need to set up a new remote that points to the original project. Change directory to the forked repository and use 'git add remote' command to specify a new remote upstream repository.
$ cd EdgeCloudSim
$ git remote add upstream git remote add upstream https://github.com/CagataySonmez/EdgeCloudSim.git
After this step, you will have two remotes on your local:
origin: points to the forked project with read and write permissions. upstream: points to the main project with read permission only.
While you are working on your own fork, please use separate and isolated branches for each topic. For new features and improvements, make your pull request to the development branch on the upstream. If you are working on bug fixes or critical updates, make your pull request to the master branch.
Please use meaningful branch names and commit messages so that we can easily understand what has been changed. You can use "bugfix/" prefix if you fix a bug, or use a "feature/" if you add a new feature.
For example, if you are fixing a bug, firstly sync with the upstream master branch:
$ git checkout master
$ git pull upstream master
If there are conflicts, resolve them and commit the merge. Then push the merge into your remote.
$ git push origin master
Now you are in sync with the upstream. Create a new branch and checkout to start working on the bug, then push your new branch to your remote
$ git checkout -b bugfix/issue#1234
$ git push -u origin bugfix/issue#1234
Implement your changes and commit them, then finally push them to the remote branch
$ git commit -m "issue#1234: prevent simulation freeze on out of memory"
$ git commit -m "issue#1234: prevent simulation freeze on timeout"
$ ...
$ git push origin bugfix/issue#1234
Open your GitHub repositories on your web browser, and find your forked EdgeCloudSim project. Your new branch will be listed at the top and you will see "Compare & pull request" button next to your new branch. Press this button, and create a pull request. Please select select correct repository and branch for the base fork and base options. According to the example given in step 3; "base fork" should be YOUR_USERNAME/EdgeCloudSim.git and "base" should be master. Please type sufficient title and description for your pull request.