aboutsummaryrefslogtreecommitdiffstats
path: root/resources/tools/vagrant/ansible/roles/csit/tasks/main.yml
blob: 9431fd53bea510854fb00d7a855d98812dd961bc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
---
# file: csit/tasks/main.yml

- name: Upload config to rename network interfaces
  copy:
    src: files/99-vppdevice.yaml
    dest: /etc/netplan/99-vppdevice.yaml
    owner: root
    group: root
    mode: 0644

- name: Apply network config changes
  command: /usr/sbin/netplan apply

- name: Install required system tools and packages
  apt:
    name:
      - wget
      - curl
      - python-pip
      - virtualenv
      - libpcap-dev
    state: present

- name: Adjust number of hugepages
  sysctl:
    name: vm.nr_hugepages
    value: 512
    state: present
    sysctl_file: /etc/sysctl.d/90-csit.conf
    reload: yes

- name: Add an Apt signing key, for docker-ce repository
  apt_key:
    url: https://download.docker.com/linux/ubuntu/gpg
    state: present

- name: Add docker-ce apt repository if not present
  apt_repository:
    repo: "deb https://download.docker.com/linux/ubuntu {{ ansible_distribution_release }} stable"
    state: present

- name: Install docker-ce if it's not already installed
  apt:
    name: docker-ce
    state: present

- name: "Add user for running tests: {{ csit.test_user.name }}"
  user:
    name: "{{ csit.test_user.name }}"
    password: "{{ csit.test_user.password }}"
    home: "{{ csit.test_user.home }}"
    shell: "{{ csit.test_user.shell }}"

- name: "Allow passwordless sudo for user: {{ csit.test_user.name }}"
  lineinfile:
    path: "/etc/sudoers.d/{{ csit.test_user.name }}"
    line: "{{ csit.test_user.name }} ALL=(ALL) NOPASSWD:ALL"
    create: yes

- name: Add vagrant user to docker group
  user:
    name: vagrant
    groups:
      - docker

- name: Reload groups for current session
  command: /usr/bin/newgrp docker

- name: Load required kernel modules
  modprobe:
    name: "{{ item }}"
    state: present
  with_items:
    - vfio-pci

- name: Enable required kernel modules on boot
  lineinfile:
    path: /etc/modules
    line: "{{ item }}"
    state: present
    insertafter: EOF
  with_items:
    - vfio-pci

- name: Clone CSIT repository
  become_user: vagrant
  git:
    repo: "{{ csit.repository.url }}"
    dest: "{{ csit.home }}"
    accept_hostkey: yes
    version: "{{ csit.repository.version }}"

- name: Install and update pip and virtualenv
  become_user: vagrant
  pip:
    name:
      - pip
      - virtualenv
    state: latest

- name: Prepare python virtual environmant for CSIT
  become_user: vagrant
  command: "/usr/bin/virtualenv {{ csit.home }}/env"
  args:
    chdir: "{{ csit.home }}"
    creates: "{{ csit.home }}/env/bin/activate"

- name: Install python dependencies (from {{ csit.home }}/requirements.txt)
  become_user: vagrant
  shell: source {{ csit.home }}/env/bin/activate && pip install --timeout 300 -r {{ csit.home }}/requirements.txt
  args:
    executable: /bin/bash

- name: Load csit docker image from local drive if it exists (/vagrant/csit-sut.tar)
  shell: |
    if [ -z "$(docker images -q `cat {{ csit.home }}/VPP_DEVICE_IMAGE`)" ] && [ -e /vagrant/csit-sut.tar ]; then
      docker load -i /vagrant/csit-sut.tar;
    fi;
  ignore_errors: yes