當前位置: 首頁>>代碼示例>>Python>>正文


Python reversion.create_revision方法代碼示例

本文整理匯總了Python中reversion.create_revision方法的典型用法代碼示例。如果您正苦於以下問題:Python reversion.create_revision方法的具體用法?Python reversion.create_revision怎麽用?Python reversion.create_revision使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在reversion的用法示例。


在下文中一共展示了reversion.create_revision方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: update_institution

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def update_institution(self, no_progress, update):
        self.updated, self.inserted, self.errored, self.skipped = 0, 0, 0, 0
        with transaction.atomic() and reversion.create_revision():
            for regon in self.get_iter(self.get_queryset(update), no_progress):
                item = self.insert_throguth_terc(regon)
                if not item:
                    item = self.insert_throught_simc(regon)
                if not item:
                    self.errored += 1
        self.stdout.write(
            "There is {} connection changed, which {} updated, {} skipped and {} inserted. but {} errored.".
                format(self.updated + self.inserted,
                       self.updated,
                       self.skipped,
                       self.inserted,
                       self.errored)) 
開發者ID:ad-m,項目名稱:epuap-watchdog,代碼行數:18,代碼來源:teryt_connection.py

示例2: handle

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def handle(self, comment, no_progress, verbose, update, *args, **options):
        self.updated, self.inserted, self.skipped, self.deleted, self.missing = 0, 0, 0, 0, 0
        print(update)
        with transaction.atomic() and reversion.create_revision():
            reversion.set_comment(comment)
            for court in self.get_iter(self.get_queryset(update), no_progress):
                self.process_item(court, verbose)

        self.stdout.write(
            "There is {} connection, which {} skipped, {} updated, {} deleted, {} inserted, {} missing.".format(
                self.updated + self.inserted + self.skipped,
                self.skipped,
                self.updated,
                self.deleted,
                self.inserted,
                self.missing)) 
開發者ID:ad-m,項目名稱:epuap-watchdog,代碼行數:18,代碼來源:build_court_connection.py

示例3: player_unresponsive

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def player_unresponsive(round_, pairing, player, groups):
    has_warning = PlayerWarning.objects.filter(player=player, round__season=round_.season, type='unresponsive').exists()
    if not has_warning:
        with reversion.create_revision():
            reversion.set_comment('Automatic warning for unresponsiveness')
            PlayerWarning.objects.create(player=player, round=round_, type='unresponsive')
        punishment = 'You may receive a yellow card.'
        allow_continue = True
        groups['warning'].append(player)
    else:
        card_color = give_card(round_, player, 'card_unresponsive')
        if not card_color:
            return
        punishment = 'You have been given a %s card.' % card_color
        allow_continue = card_color != 'red'
        groups[card_color].append(player)
    signals.notify_unresponsive.send(sender=automod_unresponsive, round_=round_, player=player, punishment=punishment, allow_continue=allow_continue) 
開發者ID:cyanfish,項目名稱:heltour,代碼行數:19,代碼來源:automod.py

示例4: claim_win_noshow_approved

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def claim_win_noshow_approved(instance, **kwargs):
    p = instance.pairing
    opponent = p.white if p.white != instance.requester else p.black

    with reversion.create_revision():
        reversion.set_comment('Auto forfeit for no-show')
        if p.white == instance.requester:
            p.result = '1X-0F'
        if p.black == instance.requester:
            p.result = '0F-1X'
        p.save()
    add_system_comment(p, '%s no-show' % opponent.lichess_username)
    sp = SeasonPlayer.objects.filter(player=opponent, season=instance.season).first()
    add_system_comment(sp, 'Round %d no-show' % instance.round.number)

    card_color = give_card(instance.round, opponent, 'card_noshow')
    if not card_color:
        return
    punishment = 'You have been given a %s card.' % card_color
    allow_continue = card_color != 'red'
    signals.notify_noshow_claim.send(sender=claim_win_noshow_approved, round_=instance.round, player=opponent, punishment=punishment, allow_continue=allow_continue) 
開發者ID:cyanfish,項目名稱:heltour,代碼行數:23,代碼來源:automod.py

示例5: revoke_card

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def revoke_card(round_, player, type_):
    with transaction.atomic():
        sp = SeasonPlayer.objects.filter(season=round_.season, player=player).first()
        if not sp:
            logger.error('Season player did not exist for %s %s' % (round_.season, player))
            return
        card = PlayerWarning.objects.filter(player=player, round=round_, type=type_).first()
        if not card:
            return
        card.delete()
        has_other_card = PlayerWarning.objects.filter(player=player, round=round_, type__startswith='card').exists()
        if not has_other_card and sp.games_missed > 0:
            sp.games_missed -= 1
            with reversion.create_revision():
                reversion.set_comment('Card revocation')
                sp.save() 
開發者ID:cyanfish,項目名稱:heltour,代碼行數:18,代碼來源:automod.py

示例6: test_reversion

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def test_reversion():
    with reversion.create_revision():
        key = mommy.make(Topic, name="key1")

    key_from_db = Topic.objects.get(pk=key.pk)
    assert key.name == key_from_db.name

    with reversion.create_revision():
        key_from_db.name = "new name"
        key_from_db.save()

    key.refresh_from_db()
    assert key.name == "new name"
    assert key_from_db.name == "new name"

    versions = Version.objects.get_for_model(Topic)
    assert len(versions) == 2
    assert versions[1].field_dict["name"] == "key1"
    assert versions[0].field_dict["name"] == "new name"

    versions[1].revision.revert()

    key.refresh_from_db()
    assert key.name == "key1" 
開發者ID:18F,項目名稱:omb-eregs,代碼行數:26,代碼來源:admin_tests.py

示例7: from_row

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def from_row(self, row):
        """Retrieve/create/update a Policy object"""
        policy_number = int(row['policyNumber'])
        uri_key = find_key("uri_policy_ids", row)
        omb_key = find_key("omb_policy_ids", row)
        if policy_number not in self.policies:
            policy = Policy.objects.filter(policy_number=policy_number).first()
            policy = policy or Policy(policy_number=policy_number)
            policy.title = row['policyTitle']
            policy.uri = row[uri_key]
            policy.omb_policy_id = convert_omb_policy_id(row[omb_key])
            policy.policy_status = row.get("policyStatus", "")
            policy.policy_type = convert_policy_type(row['policyType'])
            policy.issuance = convert_date(row['policyIssuanceYear'])
            policy.sunset = convert_date(row['policySunset'])
            policy.issuing_body = row['issuingBody']
            with reversion.create_revision():
                policy.save()
            self.policies[policy_number] = policy
        return self.policies[policy_number] 
開發者ID:18F,項目名稱:omb-eregs,代碼行數:22,代碼來源:import_reqs.py

示例8: sync_row

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def sync_row(self, row):
        """Create/update a single agency from itdashboard.gov"""
        agency = Agency.objects.filter(
            omb_agency_code=row['agencyCode']).first()
        agency = agency or Agency(omb_agency_code=row['agencyCode'])
        agency.name = row['agencyName']
        agency.abbr = row['agencyAbbreviation'] or agency.abbr
        with reversion.create_revision():
            agency.save()

        agency.groups.add(self.system_groups['all-agencies'])

        if row['agencyType'] != '5-Other Branches':
            self.system_groups['executive'].agencies.add(agency)
        if row['CFO_Act']:
            self.system_groups['cfo-act'].agencies.add(agency)
        if row['CIO_Council']:
            self.system_groups['cio-council'].agencies.add(agency) 
開發者ID:18F,項目名稱:omb-eregs,代碼行數:20,代碼來源:sync_agencies.py

示例9: testRevisionSignals

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def testRevisionSignals(self):
        pre_revision_receiver_called = []
        def pre_revision_receiver(**kwargs):
            self.assertEqual(kwargs["instances"], [self.test11])
            self.assertTrue(isinstance(kwargs["revision"], Revision))
            self.assertEqual(len(kwargs["versions"]), 1)
            pre_revision_receiver_called.append(True)
        post_revision_receiver_called = []
        def post_revision_receiver(**kwargs):
            self.assertEqual(kwargs["instances"], [self.test11])
            self.assertTrue(isinstance(kwargs["revision"], Revision))
            self.assertEqual(len(kwargs["versions"]), 1)
            post_revision_receiver_called.append(True)
        reversion.pre_revision_commit.connect(pre_revision_receiver)
        reversion.post_revision_commit.connect(post_revision_receiver)
        # Create a revision.
        with reversion.create_revision():
            self.test11.save()
        # Check the signals were called.
        self.assertTrue(pre_revision_receiver_called)
        self.assertTrue(post_revision_receiver_called) 
開發者ID:osess,項目名稱:mes,代碼行數:23,代碼來源:tests.py

示例10: testRevertWithDelete

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def testRevertWithDelete(self):
        with reversion.create_revision():
            test23 = ReversionTestModel2.objects.create(
                name = "model2 instance3 version1",
            )
            self.follow1.test_model_2s.add(test23)
            self.follow1.save()
        self.assertEqual(reversion.get_for_object(test23).count(), 1)
        self.assertEqual(self.follow1.test_model_2s.all().count(), 3)
        # Test that a revert with delete works.
        test23_pk = test23.pk
        self.assertEqual(ReversionTestModel2.objects.count(), 3)
        with reversion.create_revision():
            reversion.get_for_object(self.follow1)[1].revision.revert(delete=True)
        self.assertEqual(ReversionTestModel1.objects.get(id=self.test11.pk).name, "model1 instance1 version1")
        self.assertEqual(ReversionTestModel2.objects.get(id=self.test22.pk).name, "model2 instance2 version1")
        self.assertEqual(ReversionTestModel2.objects.get(id=self.test22.pk).name, "model2 instance2 version1")
        self.assertEqual(ReversionTestModel2.objects.count(), 2)
        self.assertRaises(ReversionTestModel2.DoesNotExist, lambda: ReversionTestModel2.objects.get(id=test23_pk))
        # Roll back to the revision where all models were present.
        reversion.get_for_object(self.follow1)[1].revision.revert()
        self.assertEqual(self.follow1.test_model_2s.all().count(), 3)
        # Roll back to a revision where a delete flag is present.
        reversion.get_for_object(self.follow1)[0].revision.revert(delete=True)
        self.assertEqual(self.follow1.test_model_2s.all().count(), 2) 
開發者ID:osess,項目名稱:mes,代碼行數:27,代碼來源:tests.py

示例11: handle

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def handle(self, infile, comment, no_progress, *args, **options):
        self.esp_cache = {}
        self.updated, self.inserted, self.skipped = 0, 0, 0
        self.regon_fixed = 0
        self.esp_updated, self.esp_inserted, self.esp_skipped = 0, 0, 0
        self.no_progress = no_progress
        with transaction.atomic() and reversion.create_revision():
            reversion.set_comment(comment)
            # Transaction usage means that the disk has been written to the disk only after commit,
            # which greatly influences the speed.
            for epuap_id, esps in self.get_iter(self.generate_data(infile)):
                items = list(esps)
                regon = items[0]['regon'] if items[0]['regon'] != 'NULL' else None
                institution = Institution.objects.get_or_create(epuap_id=epuap_id,
                                                                defaults={'regon': regon,
                                                                          'name': items[0]['name']})[0]
                self._process_resp(institution, items[0])
                self._process_esps(institution, items)

        self.stdout.write("There is {} RESPs {} skipped and changed, which {} updated and {} inserted.".format(
            self.updated + self.inserted + self.skipped,
            self.skipped,
            self.updated,
            self.inserted))
        self.stdout.write("There is {} REGON's fixed in institution".format(self.regon_fixed))
        self.stdout.write(("There is {} ESPs changed, which {} skipped, {} "
                           "updated and {} inserted.").format(self.esp_updated + self.esp_inserted + self.esp_skipped,
                                                              self.esp_skipped,
                                                              self.esp_updated,
                                                              self.esp_inserted)) 
開發者ID:ad-m,項目名稱:epuap-watchdog,代碼行數:32,代碼來源:load_resp.py

示例12: handle

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def handle(self, comment, institutions_id, update, no_progress, *args, **options):
        gus = GUS(api_key=settings.GUSREGON_API_KEY, sandbox=settings.GUSREGON_SANDBOX)
        if settings.GUSREGON_SANDBOX is True:
            self.stderr.write("You are using sandbox mode for the REGON database. Data may be incorrect. "
                              "Set the environemnt variable GUSREGON_SANDBOX and GUSREGON_API_KEY correctly.")
        inserted, updated, errored, skipped = 0, 0, 0, 0
        qs = self.get_queryset(update, institutions_id)
        for institution in self.get_iter(qs, no_progress):
            with transaction.atomic() and reversion.create_revision():
                try:
                    data = gus.search(regon=normalize_regon(institution.regon))
                except TypeError as e:
                    regon_obj = REGON.objects.create(institution=institution, regon=institution.regon)
                    REGONError.objects.create(regon=regon_obj, exception=repr(e))
                    errored += 1
                    self.stderr.write("Errored for {} in {} as {}".format(institution.regon, institution.pk, repr(e)))
                    continue
                if hasattr(institution, 'regon_data'):
                    if institution.regon_data.data != data:
                        institution.regon_data.regon = institution.regon
                        institution.regon_data.data = data
                        institution.regon_data.save()
                        updated += 1
                    else:
                        skipped += 1
                else:
                    REGON.objects.create(institution=institution,
                                         regon=institution.regon,
                                         data=data)
                    inserted += 1
                reversion.set_comment(comment)
            time.sleep(2)
        total = updated + inserted + errored + skipped
        self.stdout.write(("There is {} REGON changed, which "
                           "{} updated, "
                           "{} skipped, "
                           "{} inserted and "
                           "{} errored.").format(total, updated, skipped, inserted, errored)) 
開發者ID:ad-m,項目名稱:epuap-watchdog,代碼行數:40,代碼來源:update_regon.py

示例13: update_regon

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def update_regon(self, no_progress, update):
        self.updated, self.inserted, self.errored, self.skipped = 0, 0, 0, 0
        with transaction.atomic() and reversion.create_revision():
            for regon in self.get_iter(self.get_queryset_regon(update), no_progress):
                jst_id = get_jst_id(regon.data)
                jst = self.get_jst(jst_id)
                if not jst:
                    self.stderr.write("Unable to find JST {} for {}".format(jst_id, regon))
                    self.errored +=1
                    continue
                if hasattr(regon, 'regonjst'):
                    if regon.regonjst.jst == jst:
                        self.skipped += 1
                    else:
                        self.updated += 1
                        regon.regonjst.jst = jst
                        regon.regonjst.save()
                else:
                    self.inserted += 1
                    REGONJST.objects.create(regon=regon, jst=jst)

        self.stdout.write(
            "There is {} connection changed, which {} updated, {} skipped and {} inserted. but {} errored.".
                format(self.updated + self.inserted,
                       self.updated,
                       self.skipped,
                       self.inserted,
                       self.errored)) 
開發者ID:ad-m,項目名稱:epuap-watchdog,代碼行數:30,代碼來源:teryt_connection.py

示例14: handle

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def handle(self, krs, regon, nip, comment, google, no_progress, no_regon, no_nip, *args, **options):
        gus = GUS(api_key=settings.GUSREGON_API_KEY, sandbox=settings.GUSREGON_SANDBOX)
        if settings.GUSREGON_SANDBOX is True:
            self.stderr.write("You are using sandbox mode for the REGON database. Data may be incorrect. "
                              "Set the environemnt variable GUSREGON_SANDBOX and GUSREGON_API_KEY correctly.")
        self.inserted, self.updated, self.errored, self.skipped = 0, 0, 0, 0

        if not any([krs, regon, nip, google]):
            raise CommandError("Provide at least one '--krs' or '--regon' or '--nip' or '--google' is required. ")

        queries = self.get_queryset(krs, nip, regon, google, no_regon, no_nip)

        with transaction.atomic() and reversion.create_revision():
            reversion.set_comment(comment)
            for query in self.get_iter(queries, no_progress):
                data = gus.search(**query)
                if data:
                    regon_id = query.get('regon', data.get('regon14', data.get('regon9')))
                    try:
                        regon = REGON.objects.regon(regon_id)
                        if regon.data != data:
                            regon.data = data
                            regon.save()
                            self.updated += 1
                        else:
                            self.skipped += 1
                    except REGON.DoesNotExist:
                        regon = REGON(regon=regon_id, data=data)
                        self.stdout.write("Added {}".format(regon.data.get('nazwa', '')))
                        regon.save()
                        self.inserted += 1
                else:
                    self.stderr.write("Unable to find {}".format(query))
                    self.errored += 1

        total = self.inserted + self.updated + self.errored
        self.stdout.write(("There is {} REGON changed, which "
                           "{} updated, "
                           "{} skipped, "
                           "{} inserted and "
                           "{} errored.").format(total, self.updated, self.skipped, self.inserted, self.errored)) 
開發者ID:ad-m,項目名稱:epuap-watchdog,代碼行數:43,代碼來源:query_regon.py

示例15: handle

# 需要導入模塊: import reversion [as 別名]
# 或者: from reversion import create_revision [as 別名]
def handle(self, no_progress, verbose, comment, *args, **options):
        gus = GUS(api_key=settings.GUSREGON_API_KEY, sandbox=settings.GUSREGON_SANDBOX)
        if settings.GUSREGON_SANDBOX is True:
            self.stderr.write("You are using sandbox mode for the REGON database. Data may be incorrect. "
                              "Set the environemnt variable GUSREGON_SANDBOX and GUSREGON_API_KEY correctly.")
        self.inserted, self.updated, self.errored, self.skipped = 0, 0, 0, 0
        qs = self.get_queryset()
        for regon in self.get_iter(qs, no_progress):
            with transaction.atomic() and reversion.create_revision():
                data = gus.search(regon=regon.data['regon14'], report_type='PublDaneRaportLokalnePrawnej', list=True)
                for item in data:
                    # item_data = gus.search(regon=item['regon14'])
                    item_data = item
                    try:
                        obj = REGON.objects.get(regon=item['regon14'])
                        if obj.data != item_data:
                            obj.data = item_data
                            obj.save()
                            self.updated += 1
                        else:
                            self.skipped += 1
                    except REGON.DoesNotExist:
                        REGON.objects.create(regon=item['regon14'], data=item_data)
                        self.inserted += 1
        self.stdout.write("There is {} courts, which {} skipped, {} updated and {} inserted.".format(
            self.updated + self.inserted + self.skipped,
            self.skipped,
            self.updated,
            self.inserted)) 
開發者ID:ad-m,項目名稱:epuap-watchdog,代碼行數:31,代碼來源:load_related_regon.py


注:本文中的reversion.create_revision方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。