Compare commits

..

No commits in common. "master" and "drone" have entirely different histories.

5 changed files with 28 additions and 70 deletions

View File

@ -1,25 +1,20 @@
kind: pipeline kind: pipeline
type: exec type: exec
name: build name: default
platform:
os: linux
arch: amd64
steps: steps:
- name: build - name: build
commands: commands:
- docker-compose -p pycms build - docker-compose -p pycms build
- docker-compose -p pycms push - name: test
commands:
- docker-compose -p pycms up --build --abort-on-container-exit
- name: run
commands:
- docker-compose -p pycms up -d
---
name: test
type: docker
kind: pipeline
steps:
- name: run db
image: mongo
detach: true
- name: run_tests
image: pycms_server
commands:
- bash ./test.sh
depends_on:
- build

View File

@ -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

View File

@ -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:

55
main.py
View File

@ -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)

View File

@ -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'