A repository for the Cardiff School of Mathematics Code Club: an extra curricular club open to all.
The website for code club is located here - http://cardiffmathematicscodeclub.github.io/
Meeting time: Tuesday's 17:00-19:00 in room M/0.33.
In order to run the website locally you need to make sure you have all the dependencies installed. This repository uses the Bundle ruby gem to manage it's dependencies. To install bundle run the following
$ gem install bundle
Next you need to have forked this repository, you can do that by clicking the
Fork
button in upper right part of this webpage. Then clone your fork to your
computer by running
$ git clone https://github.com/<your_user_name>/CardiffMathematicsCodeClub.github.io
Then once you are in the same folder as this README run
$ bundle install
That will install everything you need to run this site and the tests. To view your local copy of the website run
$ jekyll serve
Then open the url given in a web browser to view the site.
Any changes you make to a page should automatically updated when viewing locally. If nothing changes, check the terminal from where jekyll has been run to see if there are any errors.
Alternatively, you can use docker to build and serve the site for you. If you haven't used docker before here are instructions to get started on Linux, Mac or Windows.
Once you have docker installed you can build the container image by running the
following command from the same directory as the Dockerfile
.
$ docker build -t jekyll:codeclubweb .
Where jekyll:codecodeclub
is the name that will be given to the container when it
is built. You can replace this with whatever you like provided you stick with the
<repository>:<label>
format.
Important!: You will need to rebuild your image if changes to the Gemfile
are made.
Once docker has successfully built the image you can build and view the site locally by running the following
$ docker run --rm -it -v /full/path/to/this/repository:/site -p 4000:4000 jekyll:codeclubweb
You should see some output from Jekyll saying that it is building and serving the site
and if you open your web browser to http://127.0.0.1:4000
then you should see the
code club web site in all of it's glory.
To finish up here is a quick rundown on what that command means above:
-
docker run
: We say to docker we want to create a new instance of an image as a container -
--rm
: Clean up after the container when it exits -
-it
: We want the container run interactively (so we can see it's output) -
-v /full/path/to/this/repository:/site
: This is how we load the website into the container using something called volumes. Essentially there is a folder inside the image called/site
which when we create a new container we want to mount the folder/full/path/to/this/repository
into it, this is so that the Jekyll process running inside the container can see the website and build it. Note: It's important that that you include the full filepath to this folder. A quicker way you could type this part of the command on Linux, would be to use the following-v $(pwd):/site
-
-p 4000:4000
As well as the site data, our web browser needs to communicate with the Jekyll process to view the generated website, so this command maps the container's internal port 4000 to your machine's port 4000 so that your browser can make the connection. -
jekyll:codeclubweb
: Finally we need to tell docker which image to create an container of, this is simply the name you gave it when you built the image above.
Contributions are made to this site by making pull requests if you followed the installation guide above then you should already have your own fork of this repository. You make changes to you fork and then make a pull request against this repository containing your changes.
There are a number of tests that we run on the site to (at least try to) ensure that changes to the website don't break anything.
The tests check:
- That generated HTML is sensible
- Links on the website actually link to something
So please when you are making changes to the website and before you open a pull request, run the tests to make sure you haven't broken anything which was previously working.
You can run the tests using the following command
$ rake test
If you are making a draft post (you can do this by editing a *.md file in the
_drafts
folder) and want to preview it locally you can run the following.
$ jekyll serve --drafts
The draft blog post will appear as the latest post.
If you wanted to highlight several lines of code and also have syntax highlighting then you have triple back-ticks.
We do it like this (ignore the \ at the beginning of the triple back-ticks):
\```NAME-OF-LANGUAGE
Put the code here.
\```
For example, if I wanted to input the code from Q1 of the 2015/16 Computing for Mathematics class test, I would type (again ignoring the \ before the triple back-ticks):
\```python
def mysqrt(K, epsilon=.001):
X = K / 4.0
while abs(X ** 2 - K) > epsilon:
X = (X + K / X) / 2
return X
for n in range(1, 10001): # A loop to test a bunch of values
approx = mysqrt(n)
true = n ** .5
print approx, true, approx - true # Printing the 3 results
\```
And in a page it would look like:
def mysqrt(K, epsilon=.001):
X = K / 4.0
while abs(X ** 2 - K) > epsilon:
X = (X + K / X) / 2
return X
for n in range(1, 10001): # A loop to test a bunch of values
approx = mysqrt(n)
true = n ** .5
print approx, true, approx - true # Printing the 3 results
The functional tests are class based and all classes include a 'User Story'. Whenever a new feature/page is added to the site a corresponding test should be written (note that at present not all tests that are needed are written). In fact 'Test Driven Development' is the correct way to write any code:
- Write a test
- Check that tests fails
- Write feature that stops test from failing
Obey the Testing Goat! Do Nothing Until You Have a Test
A great explanation of this process is given in this book (free to read online and where the goat image is taken from).