Merge branch 'bobthe' of https://bitbucket.org/yackob03/quay into bobthe

This commit is contained in:
Joseph Schorr 2014-02-11 16:57:22 -05:00
commit 9616c32409
5 changed files with 27 additions and 23 deletions

View file

@ -1,5 +1,4 @@
import logging import logging
import os
from app import app as application from app import app as application
from data.model import db as model_db from data.model import db as model_db

View file

@ -1,5 +1,4 @@
import logging import logging
import os
import logstash_formatter import logstash_formatter
from peewee import MySQLDatabase, SqliteDatabase from peewee import MySQLDatabase, SqliteDatabase
@ -93,7 +92,8 @@ class RedisBuildLogs(object):
class TestBuildLogs(object): class TestBuildLogs(object):
BUILDLOGS = TestBuildLogs('logs.quay.io') BUILDLOGS = TestBuildLogs('logs.quay.io', 'devtable', 'building',
'deadbeef-dead-beef-dead-beefdeadbeef')
class StripeTestConfig(object): class StripeTestConfig(object):

View file

@ -215,6 +215,8 @@ class RepositoryBuild(BaseModel):
resource_key = CharField() resource_key = CharField()
tag = CharField() tag = CharField()
phase = CharField(default='waiting') phase = CharField(default='waiting')
started = DateTimeField(default=datetime.now)
class QueueItem(BaseModel): class QueueItem(BaseModel):

View file

@ -1147,6 +1147,7 @@ def build_status_view(build_obj):
return { return {
'id': build_obj.uuid, 'id': build_obj.uuid,
'phase': build_obj.phase, 'phase': build_obj.phase,
'started': build_obj.started,
'status': status, 'status': status,
} }

View file

@ -12,10 +12,11 @@ logger = logging.getLogger(__name__)
class TestBuildLogs(BuildLogs): class TestBuildLogs(BuildLogs):
TEST_BUILD_ID = 'deadbeef-dead-beef-dead-beefdeadbeef' def __init__(self, redis_host, namespace, repository, test_build_id):
def __init__(self, redis_host):
super(TestBuildLogs, self).__init__(redis_host) super(TestBuildLogs, self).__init__(redis_host)
self.namespace = namespace
self.repository = repository
self.test_build_id = test_build_id
self.last_command = 0 self.last_command = 0
self.logs = [self._generate_command()] self.logs = [self._generate_command()]
self.commands = [{ self.commands = [{
@ -24,6 +25,7 @@ class TestBuildLogs(BuildLogs):
}] }]
self.request_counter = 0 self.request_counter = 0
self._generate_logs() self._generate_logs()
self._status = {}
def _get_random_command(self): def _get_random_command(self):
COMMANDS = ['FROM', 'MAINTAINER', 'RUN', 'CMD', 'EXPOSE', 'ENV', 'ADD', COMMANDS = ['FROM', 'MAINTAINER', 'RUN', 'CMD', 'EXPOSE', 'ENV', 'ADD',
@ -61,7 +63,7 @@ class TestBuildLogs(BuildLogs):
}) })
@staticmethod @staticmethod
def generate_image_completion(rand_func): def _generate_image_completion(rand_func):
images = {} images = {}
for image_id in range(rand_func.randint(1, 11)): for image_id in range(rand_func.randint(1, 11)):
total = int(math.pow(abs(rand_func.gauss(0, 1000)), 2)) total = int(math.pow(abs(rand_func.gauss(0, 1000)), 2))
@ -73,13 +75,7 @@ class TestBuildLogs(BuildLogs):
} }
return images return images
@staticmethod def _generate_fake_status(self):
def generate_fake_status():
response = {
'id': 'deadbeef-dead-beef-dead-beefdeadbeef',
'status': None,
}
random = SystemRandom() random = SystemRandom()
phases = { phases = {
'waiting': {}, 'waiting': {},
@ -98,18 +94,22 @@ class TestBuildLogs(BuildLogs):
'total_commands': 7, 'total_commands': 7,
'current_command': 7, 'current_command': 7,
'push_completion': random.random(), 'push_completion': random.random(),
'image_completion': TestBuildLogs.generate_image_completion(random), 'image_completion': self._generate_image_completion(random),
}, },
} }
phase = random.choice(phases.keys()) phase = random.choice(phases.keys())
response['phase'] = phase
response['status'] = (phases[phase])
return response from data import model
build_obj = model.get_repository_build(self.namespace, self.repository,
self.test_build_id)
build_obj.phase = phase
build_obj.save()
return phases[phase]
def get_log_entries(self, build_id, start_index, end_index): def get_log_entries(self, build_id, start_index, end_index):
if build_id == self.TEST_BUILD_ID: if build_id == self.test_build_id:
self.request_counter += 1 self.request_counter += 1
if self.request_counter % 10 == 0: if self.request_counter % 10 == 0:
self._generate_logs() self._generate_logs()
@ -122,7 +122,7 @@ class TestBuildLogs(BuildLogs):
end_index) end_index)
def get_commands(self, build_id): def get_commands(self, build_id):
if build_id == self.TEST_BUILD_ID: if build_id == self.test_build_id:
self.request_counter += 1 self.request_counter += 1
if self.request_counter % 10 == 0: if self.request_counter % 10 == 0:
self._generate_logs() self._generate_logs()
@ -131,7 +131,7 @@ class TestBuildLogs(BuildLogs):
return super(TestBuildLogs, self).get_commands(build_id) return super(TestBuildLogs, self).get_commands(build_id)
def get_last_command(self, build_id): def get_last_command(self, build_id):
if build_id == self.TEST_BUILD_ID: if build_id == self.test_build_id:
self.request_counter += 1 self.request_counter += 1
if self.request_counter % 10 == 0: if self.request_counter % 10 == 0:
self._generate_logs() self._generate_logs()
@ -140,10 +140,12 @@ class TestBuildLogs(BuildLogs):
return super(TestBuildLogs, self).get_last_command(build_id) return super(TestBuildLogs, self).get_last_command(build_id)
def get_status(self, build_id): def get_status(self, build_id):
if build_id == self.TEST_BUILD_ID: if build_id == self.test_build_id:
self.request_counter += 1 self.request_counter += 1
if self.request_counter % 10 == 0: if self.request_counter % 10 == 0:
self._generate_logs() self._generate_logs()
return self.generate_fake_status() last_status = self._status
self._status = self._generate_fake_status()
return last_status
else: else:
return super(TestBuildLogs, self).get_status(build_id) return super(TestBuildLogs, self).get_status(build_id)