1
0
forked from ovh/pci-test
Go to file
Arnaud Morin a1ab1f4dcc Add info about forking
Signed-off-by: Arnaud Morin <arnaud.morin@ovhcloud.com>
2024-10-25 23:57:34 +02:00
ex1 Add readme 2024-10-25 23:50:25 +02:00
ex2 add app binary 2024-10-25 23:50:25 +02:00
ex3 Add readme 2024-10-25 23:50:25 +02:00
ex4 Add readme 2024-10-25 23:50:25 +02:00
README.md Add info about forking 2024-10-25 23:57:34 +02:00

Intro

We created this set of exercises to give you the opportunity to express yourself technically. Do as much as you can in the time you have. Feel free to ask us questions, if any. No worries if you can't make it all by lack of time or understanding of what we're asking. We'll defrief it with you during our next call.

Have fun!

Fork

Register an account and fork this repo.

You will push your results to your fork.

Ex. 1 - python

This exercise will be split into multiple smaller ones. For each one you can create files named a.py, b.py and c.py. You maybe resuse the same environment for all sub-exercises

Guidelines:

  • Use python version python3.7+.
  • Unless specified otherwise you can only use builtin modules.

python - A

Write a script that prints out whatever text input is passed as argument

Example:

$ python a.py ping ping ping
ping ping ping

python - B

Write a script take takes one argument (-t/--target) which can only accept the following values titi, toto, tata. When called with a valid target, the script should print out the target text to stdout (titi, toto or tata). When an invalid target is provided an error message should be printed to stderr

Example:

$ python b.py --target titi
titi

$ python b.py -t tutu
usage: b.py [-h] [-t {titi,toto,tata}]
b.py: error: argument -t/--target: invalid choice: 'tutu' (choose from 'titi', 'toto', 'tata')

python - C

Write a script that creates ascii art equivalent of text passed as argument. For this exercise you may use a 3rd party module.

Example:

$ python c.py 'Hello buddies'
 _   _        _  _          _                 _      _  _
| | | |  ___ | || |  ___   | |__   _   _   __| |  __| |(_)  ___  ___
| |_| | / _ \| || | / _ \  | '_ \ | | | | / _` | / _` || | / _ \/ __|
|  _  ||  __/| || || (_) | | |_) || |_| || (_| || (_| || ||  __/\__ \
|_| |_| \___||_||_| \___/  |_.__/  \__,_| \__,_| \__,_||_| \___||___/

Ex. 2 - docker

In ex2 folder, you will find a app binary.

Can you build very lighweight docker image that contains ONLY app binary, and that execute app by default?

Push your Dockerfile in the ex2 folder.

Ex. 3 - terraform

In ex3 folder, you will find an incomplete openrc file.

You will need to amend the file to configure the correct OS_USERNAME, OS_PASSWORD and OS_REGION_NAME with the one that we gave to you.

Then, using terraform, can you write a plan to boot a d2-4 with a floating IP.

Bonus, on that instance, make sure a web server (nginx) is running.

Push your main.tf file in ex3 folder.

Ex. 4 - git

In this repo, there are two branches:

  • stein
  • queens

Stein contains the following commits:

Queens contains the following commits:

So the common ancestor is A (same commit ID).

B has been cherry-picked from stein to queens, without conflicts.

F has also been cherry-picked but with conflicts (solved, of course).

Exercice

You will need to create two branches:

  • merged
  • rebased

Merged

Create the merged branch first:

git checkout -b merged origin/queens

Then merge the stein branch into your branch

git merge origin/stein

You will have a conflict to solved.

Solve it, then push your merged branch to your repo.

Rebased

Now create the rebased branch:

git checkout -b rebased origin/queens

Now rebase it on top of stein:

git rebase -i origin/stein

You will have a conflict to solved.

Solve it, then push your rebased branch to your repo.

Check diff

Now check the diff between your two branches merged and rebased.

git diff merged..rebased

Can you explain why you have a diff?

Write down the explanation in ex4 folder (like in a README.md file)