本文整理匯總了Python中celery.uuid方法的典型用法代碼示例。如果您正苦於以下問題:Python celery.uuid方法的具體用法?Python celery.uuid怎麽用?Python celery.uuid使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類celery
的用法示例。
在下文中一共展示了celery.uuid方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_backend__pickle_serialization
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def test_backend__pickle_serialization(self):
self.app.conf.result_serializer = 'pickle'
self.app.conf.accept_content = {'pickle', 'json'}
self.b = DatabaseBackend(app=self.app)
tid2 = uuid()
result = {'foo': 'baz', 'bar': SomeClass(12345)}
self.b.mark_as_done(tid2, result)
# is serialized properly.
rindb = self.b.get_result(tid2)
assert rindb.get('foo') == 'baz'
assert rindb.get('bar').data == 12345
tid3 = uuid()
try:
raise KeyError('foo')
except KeyError as exception:
self.b.mark_as_failure(tid3, exception)
assert self.b.get_status(tid3) == states.FAILURE
assert isinstance(self.b.get_result(tid3), KeyError)
示例2: xxx_backend
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def xxx_backend(self):
tid = uuid()
assert self.b.get_status(tid) == states.PENDING
assert self.b.get_result(tid) is None
self.b.mark_as_done(tid, 42)
assert self.b.get_status(tid) == states.SUCCESS
assert self.b.get_result(tid) == 42
tid2 = uuid()
try:
raise KeyError('foo')
except KeyError as exception:
self.b.mark_as_failure(tid2, exception)
assert self.b.get_status(tid2) == states.FAILURE
assert isinstance(self.b.get_result(tid2), KeyError)
示例3: costruisci_e_accoda
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def costruisci_e_accoda(oggetto=None, modello=None, corpo=None, mittente=None,
destinatari=None, allegati=None, **kwargs):
"""
Scorciatoia per costruire rapidamente un messaggio di posta e inviarlo alla coda celery.
:param oggetto: Oggetto deltilizzare per l'invio.
:param modello: Modello da utilizzare per l'invio.
:param corpo: Sostituzioni da fare nel modello. Dizionario {nome: valore}
:param mittente: Mittente del messaggio. None per Notifiche da Gaia.
:param destinatari: Un elenco di destinatari (oggetti Persona).
:param allegati: Allegati messaggio
:return: Un oggetto Messaggio accodato.
"""
msg = Messaggio.costruisci_email(oggetto=oggetto, modello=modello,
corpo=corpo, mittente=mittente,
destinatari=destinatari,
allegati=allegati, **kwargs)
# Crea un ID per il task Celery
msg.task_id = uuid()
msg.save()
invia_mail.apply_async((msg.pk,), task_id=msg.task_id)
return msg
示例4: task_pcap_create
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def task_pcap_create():
"""Endpoint for network/pcap analysis task."""
if 'pcap' not in request.files:
# no pcap file
res = ErrorAPIResponse(2010).to_dict()
return jsonify(res), 400
pcap_file = request.files['pcap']
if pcap_file.filename == '':
# noname file
res = ErrorAPIResponse(2011).to_dict()
return jsonify(res), 400
# get pretty print parameter
pretty = False
if 'pretty' in request.form:
pretty = request.form['pretty']
if pretty not in ('true', 'false'):
res = ErrorAPIResponse(2000).to_dict()
return jsonify(res), 400
task_id = uuid()
# prepare directory and save pcap
os.mkdir(f'{storage_path}/{task_id}')
pcap_path = f'{storage_path}/{task_id}/{pcap_file.filename}'
pcap_file.save(pcap_path)
# run pcap analysis
args = (pcap_path,)
kwargs = {'pretty': pretty}
tasks.pcap_analysis.apply_async(args, kwargs, task_id=task_id)
res = {
'task_id': task_id
}
return jsonify(res)
示例5: handleCreateRelease
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def handleCreateRelease(token, package, title, ref):
if not token.canOperateOnPackage(package):
return error(403, "API token does not have access to the package")
if not package.checkPerm(token.owner, Permission.MAKE_RELEASE):
return error(403, "Permission denied. Missing MAKE_RELEASE permission")
five_minutes_ago = datetime.datetime.now() - datetime.timedelta(minutes=5)
count = package.releases.filter(PackageRelease.releaseDate > five_minutes_ago).count()
if count >= 2:
return error(429, "Too many requests, please wait before trying again")
rel = PackageRelease()
rel.package = package
rel.title = title
rel.url = ""
rel.task_id = uuid()
rel.min_rel = None
rel.max_rel = None
db.session.add(rel)
db.session.commit()
makeVCSRelease.apply_async((rel.id, ref), task_id=rel.task_id)
return jsonify({
"success": True,
"task": url_for("tasks.check", id=rel.task_id),
"release": rel.getAsDictionary()
})
示例6: test_forget
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def test_forget(self):
tid = uuid()
self.b.mark_as_done(tid, {'foo': 'bar'})
x = self.app.AsyncResult(tid)
assert x.result.get('foo') == 'bar'
x.forget()
if celery.VERSION[0:3] == (3, 1, 10):
# bug in 3.1.10 means result did not clear cache after forget.
x._cache = None
assert x.result is None
示例7: test_mark_as_done
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def test_mark_as_done(self):
tid = uuid()
assert self.b.get_status(tid) == states.PENDING
assert self.b.get_result(tid) is None
self.b.mark_as_done(tid, 42)
assert self.b.get_status(tid) == states.SUCCESS
assert self.b.get_result(tid) == 42
示例8: test_forget
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def test_forget(self):
tid = uuid()
self.b.mark_as_done(tid, {'foo': 'bar'})
assert self.b.get_result(tid).get('foo') == 'bar'
self.b.forget(tid)
assert tid not in self.b._cache
assert self.b.get_result(tid) is None
示例9: test_is_pickled
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def test_is_pickled(self):
tid2 = uuid()
result = {'foo': 'baz', 'bar': SomeClass(12345)}
self.b.mark_as_done(tid2, result)
# is serialized properly.
rindb = self.b.get_result(tid2)
assert rindb.get('foo') == 'baz'
assert rindb.get('bar').data == 12345
示例10: test_mark_as_failure
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def test_mark_as_failure(self):
einfo = None
tid3 = uuid()
try:
raise KeyError('foo')
except KeyError as exception:
einfo = ExceptionInfo(sys.exc_info())
self.b.mark_as_failure(tid3, exception, traceback=einfo.traceback)
assert self.b.get_status(tid3) == states.FAILURE
assert isinstance(self.b.get_result(tid3), KeyError)
assert self.b.get_traceback(tid3) == einfo.traceback
示例11: create_task_result
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def create_task_result(self):
id = uuid()
taskmeta, created = TaskResult.objects.get_or_create(task_id=id)
return taskmeta
示例12: send_via_mail
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def send_via_mail(self, redirect_url, target):
task = send_mail.apply_async(args=(self.get_user_pk, target), task_id=uuid())
# messages.add_message(self.request, messages.INFO, self.CELERY_TASK_PREFIX+task.id)
return redirect_url
示例13: make
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def make(self):
# Verifica appartenenza dell'elenco richiesto.
if not self.may_be_downloaded_async:
return self.download() # scarica direttamente
# Create new record in DB
task_uuid = uuid()
report_db = ReportElenco(report_type=self.elenco_report_type,
task_id=task_uuid,
user=self.request.user.persona)
report_db.save()
# Partire celery task e reindirizza user sulla pagina "Report Elenco"
task = generate_elenco.apply_async(
(self.celery_params, report_db.id),
task_id=task_uuid)
# Can be that the report is generated immediately, wait a bit
# and refresh db-record to verify
from time import sleep
sleep(2.5)
report_db.refresh_from_db()
if report_db.is_ready and report_db.file:
# If the report is ready, download it without redirect user
return report_db.download()
else:
response = redirect(reverse('ufficio_soci:elenchi_richiesti_download'))
messages.success(self.request, 'Attendi la generazione del report richiesto.')
return response
示例14: task_file_create
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def task_file_create():
"""Endpoint for full analysis task."""
if 'file' not in request.files:
# no file
res = ErrorAPIResponse(2020).to_dict()
return jsonify(res), 400
file = request.files['file']
if file.filename == '':
# noname file
res = ErrorAPIResponse(2021).to_dict()
return jsonify(res), 400
# get pretty print parameter
pretty = False
if 'pretty' in request.form:
pretty = request.form['pretty']
if pretty not in ('true', 'false'):
res = ErrorAPIResponse(2000).to_dict()
return jsonify(res), 400
# ger exec time parameter
exec_time = 20
if 'exec_time' in request.form:
try:
exec_time = int(request.form['exec_time'])
except ValueError:
res = ErrorAPIResponse(2022).to_dict()
return jsonify(res), 400
if (
exec_time < dynamic_config['min_exectime']
or exec_time > dynamic_config['max_exectime']
):
res = ErrorAPIResponse(2022).to_dict()
return jsonify(res), 400
task_id = uuid()
# prepare directory and save file
os.mkdir(f'{storage_path}/{task_id}')
file_path = f'{storage_path}/{task_id}/{file.filename}'
file.save(file_path)
# run analysis
args = (file_path,)
kwargs = {'pretty': pretty, 'exec_time': exec_time}
tasks.full_analysis.apply_async(args, kwargs, task_id=task_id)
res = {
'task_id': task_id
}
return jsonify(res)
示例15: create_release
# 需要導入模塊: import celery [as 別名]
# 或者: from celery import uuid [as 別名]
def create_release(package):
if not package.checkPerm(current_user, Permission.MAKE_RELEASE):
return redirect(package.getDetailsURL())
# Initial form class from post data and default data
form = CreatePackageReleaseForm()
if package.repo is not None:
form["uploadOpt"].choices = [("vcs", "From Git Commit or Branch"), ("upload", "File Upload")]
if request.method != "POST":
form["uploadOpt"].data = "vcs"
if request.method == "POST" and form.validate():
if form["uploadOpt"].data == "vcs":
rel = PackageRelease()
rel.package = package
rel.title = form["title"].data
rel.url = ""
rel.task_id = uuid()
rel.min_rel = form["min_rel"].data.getActual()
rel.max_rel = form["max_rel"].data.getActual()
db.session.add(rel)
db.session.commit()
makeVCSRelease.apply_async((rel.id, form["vcsLabel"].data), task_id=rel.task_id)
msg = "{}: Release {} created".format(package.title, rel.title)
triggerNotif(package.author, current_user, msg, rel.getEditURL())
db.session.commit()
return redirect(url_for("tasks.check", id=rel.task_id, r=rel.getEditURL()))
else:
uploadedUrl, uploadedPath = doFileUpload(form.fileUpload.data, "zip", "a zip file")
if uploadedUrl is not None:
rel = PackageRelease()
rel.package = package
rel.title = form["title"].data
rel.url = uploadedUrl
rel.task_id = uuid()
rel.min_rel = form["min_rel"].data.getActual()
rel.max_rel = form["max_rel"].data.getActual()
db.session.add(rel)
db.session.commit()
checkZipRelease.apply_async((rel.id, uploadedPath), task_id=rel.task_id)
msg = "{}: Release {} created".format(package.title, rel.title)
triggerNotif(package.author, current_user, msg, rel.getEditURL())
db.session.commit()
return redirect(url_for("tasks.check", id=rel.task_id, r=rel.getEditURL()))
return render_template("packages/release_new.html", package=package, form=form)