Skip to content

MichalisPanayides/CardiffMathematicsCodeClub.github.io

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cardiff School of Mathematics Code Club

Build Status Documentation

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.

Runing the website locally

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.

Docker

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.

Contributing

Pull Requests

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.

Tests

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

Draft Posts

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.

Code snippets

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

Writing tests

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:

  1. Write a test
  2. Check that tests fails
  3. 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).

About

A repository for the Cardiff School of Mathematics Code Club

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • SCSS 63.4%
  • HTML 23.0%
  • JavaScript 7.3%
  • Ruby 3.6%
  • Shell 2.0%
  • Dockerfile 0.7%