Compare commits
No commits in common. "master" and "prometheus-monitoring" have entirely different histories.
master
...
prometheus
27
.drone.yml
27
.drone.yml
@ -6,20 +6,17 @@ steps:
|
|||||||
- name: build
|
- name: build
|
||||||
commands:
|
commands:
|
||||||
- docker-compose -p pycms build
|
- docker-compose -p pycms build
|
||||||
- docker-compose -p pycms push
|
|
||||||
|
|
||||||
---
|
- name: test
|
||||||
name: test
|
|
||||||
type: docker
|
|
||||||
kind: pipeline
|
|
||||||
steps:
|
|
||||||
- name: run db
|
|
||||||
image: mongo
|
|
||||||
detach: true
|
|
||||||
|
|
||||||
- name: run_tests
|
|
||||||
image: pycms_server
|
|
||||||
commands:
|
commands:
|
||||||
- bash ./test.sh
|
- docker-compose -p pycms up --build --abort-on-container-exit
|
||||||
depends_on:
|
|
||||||
- build
|
- name: push
|
||||||
|
commands:
|
||||||
|
- docker-compose -p pycms push
|
||||||
|
- name: run
|
||||||
|
commands:
|
||||||
|
- docker-compose -p pycms down
|
||||||
|
- docker-compose -p pycms up -d
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,7 +2,4 @@
|
|||||||
host = db
|
host = db
|
||||||
port = 27017
|
port = 27017
|
||||||
name = pycms
|
name = pycms
|
||||||
[App]
|
|
||||||
host = 0.0.0.0
|
|
||||||
port = 8080
|
|
||||||
debug = True
|
|
||||||
|
@ -4,10 +4,10 @@ services:
|
|||||||
build: .
|
build: .
|
||||||
ports:
|
ports:
|
||||||
- 8080:8080
|
- 8080:8080
|
||||||
depends_on:
|
|
||||||
- db
|
|
||||||
volumes:
|
volumes:
|
||||||
- ./config.ini:/app/config.ini
|
- ./config.ini:/app/config.ini
|
||||||
|
depends_on:
|
||||||
|
- db
|
||||||
db:
|
db:
|
||||||
image: mongo
|
image: mongo
|
||||||
tests:
|
tests:
|
||||||
|
53
main.py
53
main.py
@ -16,10 +16,6 @@ class Config:
|
|||||||
- host
|
- host
|
||||||
- port
|
- port
|
||||||
- dbname
|
- dbname
|
||||||
App:
|
|
||||||
- host
|
|
||||||
- port
|
|
||||||
- debug
|
|
||||||
"""
|
"""
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
"""
|
"""
|
||||||
@ -32,8 +28,9 @@ class Config:
|
|||||||
print('DB not found, creating')
|
print('DB not found, creating')
|
||||||
database = mongoclient[self.dbname]
|
database = mongoclient[self.dbname]
|
||||||
|
|
||||||
|
# TODO: Create table if not exists
|
||||||
if 'posts' not in database.list_collection_names():
|
if 'posts' not in database.list_collection_names():
|
||||||
print('Table not found, creating')
|
print('Table not fount, creating')
|
||||||
posts = database['posts']
|
posts = database['posts']
|
||||||
self.posts = posts
|
self.posts = posts
|
||||||
|
|
||||||
@ -47,15 +44,11 @@ class Config:
|
|||||||
self.createConfig(config)
|
self.createConfig(config)
|
||||||
|
|
||||||
db = config['DB']
|
db = config['DB']
|
||||||
|
|
||||||
self.host = db['host']
|
self.host = db['host']
|
||||||
self.port = int(db['port'])
|
self.port = int(db['port'])
|
||||||
self.dbname = db['name']
|
self.dbname = db['name']
|
||||||
|
|
||||||
app = config['App']
|
|
||||||
self.apphost = app['host']
|
|
||||||
self.appport = int(app['port'])
|
|
||||||
self.appdebug = bool(app['debug'])
|
|
||||||
|
|
||||||
def createConfig(self, config):
|
def createConfig(self, config):
|
||||||
"""
|
"""
|
||||||
Create config file
|
Create config file
|
||||||
@ -66,12 +59,6 @@ class Config:
|
|||||||
db['port'] = '27017'
|
db['port'] = '27017'
|
||||||
db['name'] = 'pycms'
|
db['name'] = 'pycms'
|
||||||
|
|
||||||
config['App'] = {}
|
|
||||||
app = config['App']
|
|
||||||
app['port'] = '8080'
|
|
||||||
app['debug'] = 'True'
|
|
||||||
app['host'] = '0.0.0.0'
|
|
||||||
|
|
||||||
with open('config.ini', 'w') as cfgfile:
|
with open('config.ini', 'w') as cfgfile:
|
||||||
config.write(cfgfile)
|
config.write(cfgfile)
|
||||||
|
|
||||||
@ -101,38 +88,20 @@ class Back():
|
|||||||
return str(dict_posts)
|
return str(dict_posts)
|
||||||
|
|
||||||
def updatePost(self, name, body):
|
def updatePost(self, name, body):
|
||||||
|
# TODO: return RESTful error/success result
|
||||||
# If post exists, update it
|
# If post exists, update it
|
||||||
if posts.find_one({'name': name}):
|
if posts.find_one({'name': name}):
|
||||||
newPostJson = {'$set': {'text': body}}
|
newPost = {'$set': {'text': body}}
|
||||||
newPost = posts.update_one({'name': name}, newPostJson)
|
return str(posts.update_one({'name': name}, newPost))
|
||||||
result = dict(
|
|
||||||
status=200, state='updated', count=newPost.matched_count
|
|
||||||
)
|
|
||||||
# Else - create new
|
# Else - create new
|
||||||
else:
|
else:
|
||||||
newPostJson = {'name': name, 'text': body,
|
newPost = {'name': name, 'text': body,
|
||||||
'create_timestamp': str(time.time())}
|
'create_timestamp': str(time.time())}
|
||||||
newPost = posts.insert_one(newPostJson).inserted_id
|
return str(posts.insert_one(newPost).inserted_id)
|
||||||
result = dict(status=200, state='new')
|
|
||||||
return str(result)
|
|
||||||
|
|
||||||
def deletePost(self, name):
|
def deletePost(self, name):
|
||||||
delete = posts.delete_one({'name': name}).deleted_count
|
# TODO: return RESTful error/success result
|
||||||
if not delete:
|
return bool(posts.delete_one({'name': name}).deleted_count)
|
||||||
result = dict(status=500, count=delete)
|
|
||||||
else:
|
|
||||||
result = dict(status=200, count=delete)
|
|
||||||
return str(result)
|
|
||||||
|
|
||||||
|
|
||||||
class Metrics:
|
|
||||||
def alive():
|
|
||||||
return str("alive 1")
|
|
||||||
|
|
||||||
|
|
||||||
@route('/metrics')
|
|
||||||
def metrics():
|
|
||||||
return Metrics.alive()
|
|
||||||
|
|
||||||
|
|
||||||
@route('/post/<name>')
|
@route('/post/<name>')
|
||||||
@ -179,4 +148,4 @@ if __name__ == '__main__':
|
|||||||
print("Configured")
|
print("Configured")
|
||||||
back = Back()
|
back = Back()
|
||||||
posts = cfg.posts
|
posts = cfg.posts
|
||||||
run(host=cfg.apphost, port=cfg.appport, reloader=cfg.appdebug, debug=cfg.appdebug)
|
run(host='0.0.0.0', port=8080, reloader=True, debug=True)
|
||||||
|
5
test.sh
5
test.sh
@ -1,6 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
curl_cmd='curl -s -w :%{http_code}'
|
curl_cmd='curl -s -w "%{http_code}" -o /dev/null'
|
||||||
#curl_cmd='curl -s -w "%{http_code}\t%{stdout}" -o /dev/null'
|
|
||||||
url='server:8080'
|
url='server:8080'
|
||||||
$curl_cmd -X POST $url/admin/post/test -F 'body=testpage' && echo ": Create success" || echo ': create fail'
|
$curl_cmd -X POST $url/admin/post/test -F 'body=testpage' && echo ": Create success" || echo ': create fail'
|
||||||
|
|
||||||
@ -9,5 +8,3 @@ $curl_cmd $url/post/test && echo ": get Success" || echo ': get fail'
|
|||||||
$curl_cmd -X POST $url/admin/post/test -F 'body=testpage2' && echo ": Update success" || echo ': update fail'
|
$curl_cmd -X POST $url/admin/post/test -F 'body=testpage2' && echo ": Update success" || echo ': update fail'
|
||||||
|
|
||||||
$curl_cmd -X DELETE $url/admin/post/test && echo ": delete success" || echo ': delete fail'
|
$curl_cmd -X DELETE $url/admin/post/test && echo ": delete success" || echo ': delete fail'
|
||||||
|
|
||||||
$curl_cmd $url/metrics && echo ": metrics available" || echo ': metrics unavailable'
|
|
||||||
|
Loading…
Reference in New Issue
Block a user