forked from elastic/apm-server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTiltfile
122 lines (92 loc) · 3.95 KB
/
Tiltfile
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
121
122
def printup(*args):
if config.tilt_subcommand == "up":
print(*args)
config.define_bool('local-kibana')
parsed_config = config.parse()
script_dir = os.path.join(config.main_dir, 'script')
default_kibana_port = 5601
kibana_host = "localhost"
kibana_base_path = ""
# checks whether (dev mode) kibana is already running at given port,
# and returns the URL it is redirected to
def discover_kibana():
default_kibana_host = "localhost"
count = int(
str(
local("lsof -n -i :%s | grep LISTEN | wc -l | tr -d ' '" % default_kibana_port, quiet=True, echo_off=True)
).strip()
)
if count <= 0:
fail("No service found on port " + str(default_kibana_port))
return None
kibana_redirect_url = str(
local(
"curl --fail -s -I -o /dev/null -w '%{redirect_url}' " + 'http://{}:{}'.format(default_kibana_host, default_kibana_port) + ' || [ $? -eq 7 ]',
quiet=True,
echo_off=True
)
).strip().replace("http://", "")
return kibana_redirect_url
custom_build(
'apm-server',
'DOCKER_BUILDKIT=1 docker build -t $EXPECTED_REF -f packaging/docker/Dockerfile .',
deps = ['.'],
ignore = ['**/*_test.go', 'tools/**', 'systemtest/**', 'docs/**'],
)
k8s_yaml(kustomize('testing/infra/k8s/overlays/local'))
k8s_kind('ApmServer', image_json_path='{.spec.image}')
k8s_kind('Elasticsearch')
# Conditionally set up Kibana resource
discovered_kibana_url = discover_kibana() if "local-kibana" in parsed_config else None
if discovered_kibana_url and config.tilt_subcommand == "up":
printup("Waiting until local Kibana is ready at {}".format(discovered_kibana_url))
# get only the path from the URL so we can pass it separately to APM Server
url = discovered_kibana_url
if "://" in discovered_kibana_url:
url = url.split("://")[1]
kibana_base_path = url.split("/", 1)[1] if "/" in url else ""
local_resource(
"init_kibana_system_user",
cmd = """curl -s -X POST -H "Content-Type: application/json" -d '{"username":"kibana_system_user", "password":"changeme", "roles": [ "kibana_system"]}' http://admin:changeme@localhost:9200/_security/user/kibana_system_user""",
resource_deps=["elasticsearch"]
)
local_resource(
'kibana',
cmd=[ os.path.join(script_dir, 'wait_for_kibana.sh'), "http://admin:changeme@{}".format(discovered_kibana_url)],
resource_deps=["init_kibana_system_user"],
links=["http://localhost:5601"]
)
else:
printup("Starting Kibana as a container")
k8s_kind('Kibana')
k8s_resource('kibana', port_forwards=default_kibana_port, resource_deps=['elasticsearch'])
# Build and install the APM integration package whenever source under
# "apmpackage" changes.
run_with_go_ver = os.path.join(script_dir, 'run_with_go_ver')
local_resource(
'apmpackage',
cmd = [os.path.join(script_dir, 'run_with_go_ver'), 'go', 'run', './cmd/runapm -init'],
dir = 'systemtest',
deps = ['apmpackage'],
resource_deps=['kibana'],
env={ "KIBANA_HOST": kibana_host, "KIBANA_BASE_PATH": kibana_base_path, "KIBANA_PORT": str(default_kibana_port) }
)
k8s_resource('elastic-operator', objects=['eck-trial-license:Secret:elastic-system'])
k8s_resource('apm-server', port_forwards=8200)
k8s_resource('elasticsearch', port_forwards=9200, objects=['elasticsearch-admin:Secret:default'])
# Delete ECK entirely on `tilt down`, to ensure `tilt up` starts from a clean slate.
#
# Without this, ECK refuses to recreate the trial license. That's expected
# for actual trial use, but we rely an Enterprise feature for local development:
# installing the integration package by uploading to Fleet.
if config.tilt_subcommand == "down":
print(local("kubectl delete --ignore-not-found namespace/elastic-system"))
# Add a button for sending trace events and metrics to APM Server.
load('ext://uibutton', 'cmd_button')
cmd_button(
'apm-server:sendotlp',
argv=['sh', '-c', 'cd systemtest && %s go run ./cmd/sendotlp' % run_with_go_ver],
resource='apm-server',
icon_name='input',
text='Send OTLP data',
)