summaryrefslogtreecommitdiff
path: root/playbooks/tutorial/tracing.yaml
blob: 3b01f10471a187841ab56c79311c6e62815d5534 (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
# Stop the basic tutorial
- name: Run docker-compose down
  when: not local
  shell:
    cmd: docker-compose -p zuul-tutorial stop
    chdir: src/opendev.org/zuul/zuul/doc/source/examples

- name: Run docker-compose down
  when: local
  shell:
    cmd: docker-compose -p zuul-tutorial stop
    chdir: ../../doc/source/examples

# Restart with the new config
- name: Run docker-compose up
  when: not local
  shell:
    cmd: docker-compose -p zuul-tutorial up -d
    chdir: src/opendev.org/zuul/zuul/doc/source/examples
  environment:
    ZUUL_TUTORIAL_CONFIG: "./tracing/etc_zuul/"

- name: Run docker-compose up
  when: local
  shell:
    cmd: docker-compose -p zuul-tutorial up -d
    chdir: ../../doc/source/examples
  environment:
    ZUUL_TUTORIAL_CONFIG: "./tracing/etc_zuul/"

# Start Jaeger
- name: Run docker-compose up
  when: not local
  shell:
    cmd: docker-compose -p zuul-tutorial-tracing up -d
    chdir: src/opendev.org/zuul/zuul/doc/source/examples/tracing

- name: Run docker-compose up
  when: local
  shell:
    cmd: docker-compose -p zuul-tutorial-tracing up -d
    chdir: ../../doc/source/examples/tracing

# Verify that Zuul runs with the new config
- name: Wait for Zuul
  uri:
    url: http://localhost:9000/api/tenant/example-tenant/status
    method: GET
    return_content: true
    status_code: 200
    body_format: json
  register: result
  retries: 30
  delay: 10
  until: result.status == 200 and result.json["zuul_version"] is defined
  changed_when: false

- name: Verify that old builds are available
  uri:
    url: "http://localhost:9000/api/tenant/example-tenant/builds"
    method: GET
    return_content: true
    status_code: 200
    body_format: json
  register: result
  failed_when: "result.json | length < 4"
  changed_when: false

# Remove the label so Zuul will post again Verified+1 which is what
# check-pipeline is looking for
- include_role:
    name: remove-verified
  vars:
    change_id: "{{ changetest1.id }}"

# Recheck the change to issue a trace
- include_role:
    name: recheck-change
  vars:
    change_id: "{{ changetest1.id }}"

- include_role:
    name: check-pipeline
  vars:
    title: "test job test1"
    projectname: test1
    check_number: 3

- name: Verify tracing information is available
  uri:
    url: http://localhost:16686/api/traces?lookback=1h&service=zuul
    method: GET
    return_content: true
    status_code: 200
    body_format: json
  register: result
  retries: 30
  delay: 10
  until: result.status == 200 and result.json["data"] | length > 0
  changed_when: false