Skip to content
This repository has been archived by the owner on Apr 12, 2022. It is now read-only.

Commit

Permalink
Updating the Readme and adding script to run e2e locally from release…
Browse files Browse the repository at this point in the history
… package
  • Loading branch information
shivramsrivastava committed May 2, 2018
1 parent abd2372 commit 0cb1a5d
Show file tree
Hide file tree
Showing 6 changed files with 140 additions and 18 deletions.
2 changes: 1 addition & 1 deletion deploy/firmament-deployment-e2e.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ spec:
spec:
containers:
- command: [/firmament/build/src/firmament_scheduler, --flagfile=/firmament/config/firmament_scheduler_cpu_mem.cfg]
image: huaweifirmament/firmament:e2e
image: huaweifirmament/firmament:latest
name: firmament-scheduler
ports:
- containerPort: 9090
Expand Down
2 changes: 1 addition & 1 deletion deploy/poseidon-deployment-e2e.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ spec:
serviceAccountName: poseidon
containers:
- command: [/poseidon, --logtostderr, --kubeConfig=, --kubeVersion=1.6, --firmamentAddress=firmament-service.poseidon-test, --firmamentPort=9090]
image: gcr.io/poseidon-173606/poseidon:latest
image: huaweiposeidon/poseidon:latest
name: poseidon
initContainers:
- name: init-firmamentservice
Expand Down
2 changes: 1 addition & 1 deletion deploy/poseidon-deployment.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ spec:
serviceAccountName: poseidon
containers:
- command: [/poseidon, --logtostderr, --kubeConfig=, --kubeVersion=1.6]
image: gcr.io/poseidon-173606/poseidon:latest
image: huaweiposeidon/poseidon:latest
name: poseidon
initContainers:
- name: init-firmamentservice
Expand Down
95 changes: 81 additions & 14 deletions docs/devel/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -43,17 +43,29 @@ $ make
Currently the Firmament repo referred in this document is our dev repo.
We will be soon pointing it toward the main [repo](https://github.com/camsas/firmament) after our features are merged.

* **Building Poseidon:**
* **Building Poseidon without Bazel:**


```
$ mkdir -p $GOPATH/src/k8s.io
$ cd $GOPATH/src/k8s.io
$ mkdir -p $GOPATH/src/github.com/kubernetes-sigs
$ cd $GOPATH/src/github.com/kubernetes-sigs
$ git clone https://github.com/kubernetes-sigs/poseidon
# cd poseidon
$ cd poseidon
$ cd cmd/poseidon
$ go build .
```

* **Building Poseidon using Bazel:**
* Refer [Bazel](https://docs.bazel.build/versions/master/install.html) on how to install Bazel.
```
$ mkdir -p $GOPATH/src/github.com/kubernetes-sigs
$ cd $GOPATH/src/github.com/kubernetes-sigs
$ git clone https://github.com/kubernetes-sigs/poseidon
$ cd poseidon
$ bazel build //cmd/poseidon
```



# Docker container Build

Expand Down Expand Up @@ -99,7 +111,8 @@ One can also use the below to get the list of supported arguments by Firmament.
```
$ ./poseidon --logtostderr \
--kubeConfig=<path_kubeconfig_file> \
--firmamentAddress=<host>:<port> \
--firmamentAddress=<host> \
--firmamentPort=<port> \
--statsServerAddress=<host>:<port> \
--kubeVersion=<Major.Minor>
```
Expand All @@ -109,7 +122,6 @@ One can also use the below to get the list of supported arguments by Firmament.
```
sudo docker run --net=host firmament:dev /firmament/build/src/firmament_scheduler \
--flagfile=/firmament/config/firmament_scheduler_cpu_mem.cfg
```

* **Running Poseidon as docker container:**
Expand All @@ -118,16 +130,31 @@ sudo docker run --net=host --volume=$GOPATH/src/github.com/kubernetes-sigs/posei
gcr.io/poseidon-173606/poseidon:latest \
--logtostderr \
--kubeConfig=/config/kubeconfig.cfg \
--firmamentAddress=<host>:<port> \
--firmamentAddress=<host> \
--firmamentPort=<port> \
--statsServerAddress=<host>:<port> \
--kubeVersion=<Major.Minor>
```

**Note:**
The order of execution is, first Firmament has to be started and then Poseidon is started with the Firmament's address.
The order of execution is, first Firmament has to be started and then Poseidon is started with the Firmament's address
and Firmament Port.
The order is required only when we run Poseidon and Firmament manually.
This order is not required for installation methods, since the Poseidon service will not start-up till Firmament service is available.

# Running Unit Tests
Using Bazel
```
$ cd $GOPATH/src/github.com/kubernetes-sigs/poseidon
$ bazel test -- //... -//hack/... -//vendor/... -//test/e2e/...
```

Using go Test
```
$ cd $GOPATH/src/github.com/kubernetes-sigs/poseidon
$ go test $(go list ./... | grep -v /vendor/ | grep -v /test/ | grep -v /hack/)
```

# Testing the setup
Run the below script and check if the pods are scheduled.
Expand All @@ -141,12 +168,52 @@ Few test scripts are available [here](https://github.com/kubernetes-sigs/poseido
To run E2E test on a local cluster.

```
cd poseidon/pkg/test
go test -args --testKubeConfig=<path to the kubeconfig file>
$ cd $GOPATH/src/github.com/kubernetes-sigs/poseidon/test/e2e
$ go test -v . -ginkgo.v \
-args -kubeconfig=/home/ubuntu/.kube/config \
-firmamentManifestPath=../../deploy/firmament-deployment-e2e.yaml \
-poseidonManifestPath=../../deploy/poseidon-deployment-e2e.yaml
```
The local cluster should have the Poseidon and Firmament already deployed and running.
Only very basic check is supported currenlty.
We will be adding more test cases to this E2E.
You can optionally modify the ```firmamentManifestPath``` and
```poseidonManifestPath``` arguments to point to your build images.
```kubeconfig``` should point to the running local k8s cluster.

***Note***
You need to have a working kubernetes cluster to run the
above test. You can optionally try ```kubetest``` , to deploy a kubernetes
cluster on your gce account. Please refer the doc [here](https://github.com/kubernetes/test-infra/tree/master/kubetest).

# Building Release packages locally

```
$ cd $GOPATH/src/github.com/kubernetes-sigs/poseidon
$ make release
```

# Testing release packages
The best way to test the release packages locally, is to run the
below script. It will build the release tar push it to docker locally and run the e2e tests.

***Note***

The ```'kubeconfig'``` path should be ```$HOME/.kube/config```.
The below script run based on the above assumptions.
And it should point to a running k8s cluster.

```
$ $GOPATH/src/github.com/kubernetes-sigs/poseidon/test/e2e
$ test/e2e-poseidon-local.sh
```

# Code contribution
We recommend running the following, before raising a PR.

This will test all the essential checks.

```
$ make verify
```

All the existing unit tests should [pass](https://github.com/kubernetes-sigs/poseidon/tree/master/docs/devel#running-unit-tests).
Also recommend to run the local release test mentioned [here](https://github.com/kubernetes-sigs/poseidon/tree/master/docs/devel#testing-release-packages).

2 changes: 1 addition & 1 deletion test/e2e-poseidon-gce.sh
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ cp /tmp/deploy/*.yaml deploy/.
cd test/e2e

# update the poseidon deployment yaml with the correct image
sed -i "s/gcr.io\/poseidon-173606\/poseidon:latest/gcr.io\/$project\/poseidon-amd64:${BUILD_VERSION}/" $POSEIDON_MANIFEST_FILE_PATH
sed -i "s/huaweiposeidon\/poseidon:latest/gcr.io\/$project\/poseidon-amd64:${BUILD_VERSION}/" $POSEIDON_MANIFEST_FILE_PATH

#Run e2e test
go test -v . -ginkgo.v -args -testNamespace=${TEST_NAMESPACE} -firmamentManifestPath=${FIRMAMENT_MANIFEST_FILE_PATH} -poseidonManifestPath=${POSEIDON_MANIFEST_FILE_PATH}
Expand Down
55 changes: 55 additions & 0 deletions test/e2e-poseidon-local.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
#!/bin/bash

# Copyright 2018 The Kubernetes Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

set -o errexit
set -o nounset
set -o pipefail

TEST_NAMESPACE="poseidon-test"

SCRIPT_ROOT=$(dirname ${BASH_SOURCE[0]})/..
echo $SCRIPT_ROOT # ../test/..

#Set environment variables
BUILD_VERSION=$(git rev-parse HEAD)
POSEIDON_ROOT_DIR=${SCRIPT_ROOT}
FIRMAMENT_MANIFEST_FILE_PATH=../../deploy/firmament-deployment-e2e.yaml
POSEIDON_MANIFEST_FILE_PATH=../../deploy/poseidon-deployment-e2e.yaml


# work from the correct path
cd $(dirname ${BASH_SOURCE[0]})/..
#Create a poseidon release and extract images and packages in the _output folder
make quick-release

#Push to local registry
docker load -i _output/release-images/amd64/poseidon-amd64.tar
# docker -- tag "gcr.io/google_containers/poseidon-amd64:${BUILD_VERSION}" "${kube_registry}/poseidon-amd64:${BUILD_VERSION}"

#Extract Deployment files and place in the deploy folder
tar -xzf _output/release-tars/poseidon-src.tar.gz -C /tmp/
cp /tmp/deploy/*.yaml deploy/.


# setup the env and correct test directory
cd test/e2e

# update the poseidon deployment yaml with the correct image
sed -i "s/huaweiposeidon\/poseidon:latest/gcr.io\/google_containers\/poseidon-amd64:${BUILD_VERSION}/" $POSEIDON_MANIFEST_FILE_PATH

#Run e2e test
go test -v . -ginkgo.v -args -firmamentManifestPath=${FIRMAMENT_MANIFEST_FILE_PATH} -poseidonManifestPath=${POSEIDON_MANIFEST_FILE_PATH}

0 comments on commit 0cb1a5d

Please sign in to comment.