本文整理匯總了Python中avocado.models.DataView.apply方法的典型用法代碼示例。如果您正苦於以下問題:Python DataView.apply方法的具體用法?Python DataView.apply怎麽用?Python DataView.apply使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類avocado.models.DataView
的用法示例。
在下文中一共展示了DataView.apply方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_sort_related
# 需要導入模塊: from avocado.models import DataView [as 別名]
# 或者: from avocado.models.DataView import apply [as 別名]
def test_sort_related(self):
"Sorts on a reverse foreign key property."
view = DataView(
json=[
{"concept": self.first_name.pk},
{"concept": self.last_name.pk},
{"concept": self.project_name.pk, "sort": "asc", "visible": False},
]
)
queryset = view.apply()
exporter = export.BaseExporter(view)
exporter.params.insert(0, (RawFormatter(keys=["pk"]), 1))
exporter.row_length += 1
self.assertEqual(
list(exporter.write(queryset.raw())),
[
(3, u"Erick", u"Smith"),
(4, u"Aaron", u"Harris"),
(5, u"Zac", u"Cook"),
(6, u"Mel", u"Brooks"),
(1, u"Eric", u"Smith"),
(2, u"Erin", u"Jones"),
],
)
示例2: setUp
# 需要導入模塊: from avocado.models import DataView [as 別名]
# 或者: from avocado.models.DataView import apply [as 別名]
def setUp(self):
management.call_command("avocado", "init", "tests", quiet=True)
salary_concept = DataField.objects.get(field_name="salary").concepts.all()[0]
view = DataView(json={"ordering": [[salary_concept.pk, "desc"]]})
self.query = view.apply(tree=models.Employee).raw()
# Ick..
self.exporter = export.BaseExporter(view)
self.exporter.params.insert(0, (RawFormatter(keys=["pk"]), 1))
self.exporter.row_length += 1
示例3: test_dataview_order_by
# 需要導入模塊: from avocado.models import DataView [as 別名]
# 或者: from avocado.models.DataView import apply [as 別名]
def test_dataview_order_by(self):
f = DataField(app_name='lexicon', model_name='month', field_name='id')
f.save()
c = DataConcept()
c.save()
cf = DataConceptField(field=f, concept=c)
cf.save()
v = DataView({'ordering': [c.pk]})
qs = Month.objects.filter(label__startswith='J').values('id')
self.assertEqual(str(v.apply(qs).query), 'SELECT "lexicon_month"."id" FROM "lexicon_month" WHERE "lexicon_month"."label" LIKE J% ESCAPE \'\\\' ORDER BY "lexicon_month"."order" ASC')
示例4: test_view
# 需要導入模塊: from avocado.models import DataView [as 別名]
# 或者: from avocado.models.DataView import apply [as 別名]
def test_view(self):
salary_field = DataField.objects.get_by_natural_key('exporting', 'title', 'salary')
salary_concept = DataConcept()
salary_concept.save()
DataConceptField(concept=salary_concept, field=salary_field, order=1).save()
view = DataView(json={'ordering': [[salary_concept.pk, 'desc']]})
query = view.apply(tree=models.Employee).raw()
# Ick..
exporter = export.CSVExporter(view)
exporter.params.insert(0, (RawFormatter(keys=['pk']), 1))
exporter.row_length += 1
buff = exporter.write(query)
buff.seek(0)
lines = buff.read().splitlines()
# Skip the header
self.assertEqual([int(x) for x in lines[1:]], [2, 4, 6, 1, 3, 5])