Thank you for your interest in contributing to ipt_connect
!
This file provides some brief advice on how to contribute properly.
-
If you've spot a bug, feel free to open an issue.
-
If you have an idea on how to improve
ipt_connect
, don't hesitate to... yes, open an issue! -
If you want to translate the interface of
ipt_connect
into your language, see README.md. -
Last but not least: if you know Python, you can do amazing things implementing issues. Some of them are marked as "good first issue". Such issues are a really good point to start from!
Also, please don't hesitate to add remarks to this guide.
-
The license is GPLv3.
-
ipt_connect
is written in Python 2.7 (see also #160). -
It uses Django 1.11 and some other libraries.
-
It uses Git for version control anf GitHub for hosting the public Git repository.
-
DjangoGirls - not only for girls!
-
git-scm - a great book about Git (and also a good keyword for googling smth Git-related).
-
Register an account on GitHub, if you haven't created it yet. For some reasons, some people are strictly against GitHub. If you are one of them but want to contribute, contact us at nickkolok[at]mail.ru and/or execom[at]iptnet.info
-
Install Linux either into dual-boot or into a virtual machine (of course, if you haven't installed it yet). As for Linux distributions, we recommend (L/X/K)Ubuntu or Mint. If you choose to use a virtual machine, we strongly recommend Oracle VirtualBox.
Note: if you are an experienced developer, you (obviously!) may use FreeBSD, ReactOS, macOS or even windows, but in this case our team will probably unable to help you with OS-specific problems.
- Install Python 2.7 and
pip
. Depending on your distribution, it should be smth like that (fordeb
-based):
sudo apt-get install python2 pip2
Ubuntu 20.04
or higher doesn't include pip
for Python 2.7. Visit this source to solve this problem
(here, and below, and forever - Google is your friend!)
- Install Git VCS:
sudo apt-get install git
- Install useful Git-related tools:
You may skip this step, but is is recommended that you install them. In case of skipping, you will able to do it later whenever you want.
sudo apt-get install gitk meld
- Tell Git about yourself (if it hasn't been done yet):
git config --global user.name "YOURNAME"
git config --global user.email "you@example.org"
Here YOURNAME
is the name of contributor that will be showed in the commit summary (e.g. John Smith
),
you@example.org
is (obviously!) your email.
-
Fork the project on GitHub by pressing the corresponding button (
Ctrl+F
is your friend in case of problems). -
Clone the forked repository and go to the cloned directory:
This can be performed from any directory, e.g. the home one ~
.
Here and below we suppose that your username on GitHub is phys
.
git clone https://github.com/phys/ipt_connect.git
cd ipt_connect
You can surely use SSH URLs if you know what they are.
Since this moment, we suppose that you are in this directory.
Note: there are a couple of subsequent ipt_connect
directories. Don't be confused!
Note: since 2018-2019, the main branch is called dev
.
- Add the central (upstream) repo to get updates from other contributors:
git remote add upstream https://github.com/IPTnet/ipt_connect.git
The propagation of changes in ipt_connect
project works in the following way:
-
To get changes from the upstream repo (that are changes done by others) to your local computer, use
git fetch upstream
-
To send your local changes to your GitHub repo (and make them public), use
git push origin branchname1:branchname2
where
branchname1
is a name of your local branch andbranchname2
is the name of remote branch (the names often are the same, but in general they can be different). -
To suggest the changes from your local repo to be accepted into the main (upstream) repo, create a pull request
- Install the reqired libraries and
gettext
to avoidCommandError
s:
pip install -r requirements.txt
sudo apt-get install gettext # Or equivalent for your distro
Note: sometimes this should be also done after updating the code from the upstream.
- Eventually, run the server!
cd ipt_connect # Again: it is a subdirectory!
python manage.py runserver
Some messages may be shown. If there are no errors, then just go to the next step.
Нou may get ImportError
s about IPTdev_errors
or smth like this, so use such command:
#This is just an example
python manage.py makemigrations IPTdev_errors
- Open 127.0.0.1:8000/IPTdev/ in your favourite browser!
If everything went right, you will see a development instance of
ipt_connect
filled with test data!
While changing the code, you should be sure that you're not breaking anything, shouldn't you? Thus, please do the following steps before you edit anything.
- Running the tests:
cd ipt_connect
python manage.py test
cd -
Note: as for now (17 Jul 2020), there are some errors related to grappelli
and loginas
.
Just ignore them.
However, there should be no errors related to ipt_connect
itself.
- Checking availability of the links and resources:
- In a terminal, start the server:
cd ipt_connect python manage.py runserver cd -
- In another terminal (i.e. without stopping the server), run:
cd ipt_connect python manage.py test IPTdev.utils.link_parser cd -
Pro tip: you can use & disown
postfix.
Then, one terminal will be enough:
cd ipt_connect
python manage.py runserver & disown
python manage.py test IPTdev.utils.link_parser
cd -
However, in this case messages from the link checker and the server itself will be messed.
The Internet is constantly changing, new files and pages appear, and old ones are deleted. And links can change their address. Broken links can damage the site. An internal link may not work due to erroneous address or removed/non-existing page. Finally, no one is safe from errors of programmers or administrators. Each dead link causes negative reaction from users. This utility crawls all the mentioned links and returns the list of non-working ones.
If you see a dead link before you've made any changes to the files - please open an issue.
If you see a dead link (that may be either internal or external) after you've changed the code, please review your changes :)
- Creating a dump of HTML code produced:
Until the proper CI is set, we use this simple tool
to check how changes in our python
code affect the real generated HTML code.
- In a terminal, start the server:
cd ipt_connect python manage.py runserver cd -
- In another terminal (i.e. without stopping the server), run:
cd ipt_connect/IPTdev/utils python dumper.py cd -
Path to dump will be printed into the terminal
Note: the dumper uses hash of the last commit to identify the dump. Thus, the dumper shouldn't be used if there are uncommited changes.
The recommendations on how to change the codebase are rather general.
-
Don't commit changes in database if they're not essential. For example, if you've runned
python manage.py createsuperuser
to log in and test something, the database will be changed. This change should not be commited. -
Always split database changes to a separate commit and describe the changes in detail. The database is a binary file, so we will not be able to rebase the changes easily.
-
If your contribution is related to an issue, don't hesitate to mention it like so:
git commit -m "Add 6-round-fights - see #13666"
see
if for refering,close
is for closing the issue (the issue closes when the pullrequest is merged).
When the code is changed and the commit is done, please check that nothing was broken. Namely:
-
Run tests (see above)
-
Check the site for dead links (also see above)
-
Create a dump of generated pages (also see above)
-
Compare the two dumps (before and after) your changes
-
using
diff -bBwEZ ...
-
using
meld
-
or using your another favourite tool to find difference in HTML code :)
Please check the difference carefully.
-
If everything is OK, your pull request is welcome!