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


Python Job.save方法代碼示例

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


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

示例1: run

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
def run(job, *args, **kwargs):
    try:
        servers = job.server_set.all()
        for server in servers:
            job.set_progress("Checking server {} for snapshots...".format(server))
            snapshots = ServerSnapshot.objects.filter(server_id=server.id)
            if not snapshots:
                job.set_progress('No snapshots exist for server {}'.format(server))
                continue

            logger.info("Found snapshot, noting for deletion...")
            job_params = DeleteSnapshotsParameters.objects.create()
            job_params.snapshots.add(*snapshots)

            logger.info("Creating job...")
            child_job = Job(
                type="delete_snapshots",
                job_parameters=job_params,
                owner=job.owner,
                parent_job=job,
            )
            child_job.save()
            child_job.server_set.add(server)

            msg = (' Job #{} has been created to delete {} snapshot{} from server '
                   '{}.').format(
                child_job.pk, len(snapshots),
                's' if len(snapshots) > 1 else '', server)
            job.set_progress(msg)
        job.set_progress('Finished looking for snapshots on servers. Check child' +
                         ' job(s) for progress updates.')
    except Exception as err:
        return ('FAILURE', '', err)

    return ('', '', '')
開發者ID:CloudBoltSoftware,項目名稱:cloudbolt-forge,代碼行數:37,代碼來源:delete_cb_snapshot.py

示例2: handle

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
    def handle(self, *args, **options):
        listings = self.get_for_page(1)

        jobs = Job.objects.all()
        for job in jobs:
            job.delete()

        for listing in listings:

            try:
                location = listing['company']['location']['city']
            except:
                location = ''

            try:
                company = str(listing['company']['name'])
            except:
                company = ''

            newjob = Job(title=listing['title'],
                         company=company,
                         location=location,
                         url=listing['url'],
                         data=json.dumps(listing),
                         created=listing['post_date'])
            newjob.save()
開發者ID:MaciejLukianski,項目名稱:snipt,代碼行數:28,代碼來源:importjobs.py

示例3: post

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
 def post(self, request):
     json_data = json.loads(request.body)
     company = Company.objects.get(user=request.user)
     job = Job(**json_data)
     job.company = company
     job.user = request.user
     job.save()
     return JsonResponse({"status": "ok", "id": job.id, 'msg': ''})
開發者ID:EdwardBetts,項目名稱:myFirstProfile,代碼行數:10,代碼來源:views.py

示例4: test_get_nonexistant_job_product

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
 def test_get_nonexistant_job_product(self):
     # make a deleted job:
     job = Job(job_name="counter")
     job.save()
     job_key = job.key()
     job.delete()
     
     response = self.client.get(reverse('jobs.product', args=(job_key,)))
     self.assertEqual(response.status_code, 404)
開發者ID:BubbleTouchSoftware,項目名稱:chirpradio,代碼行數:11,代碼來源:tests.py

示例5: create_file_job

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
def create_file_job(name, sf_id, *args, **kwargs):
    """MD5, backup, etc"""
    jobargs = [sf_id] + list(args)
    job = Job(funcname=name, jobtype=jobmap[name]['type'],
              timestamp=timezone.now(),
              state=Jobstates.PENDING, args=json.dumps(jobargs),
              kwargs=json.dumps(kwargs))
    job.save()
    FileJob.objects.create(storedfile_id=sf_id, job_id=job.id)
    return job
開發者ID:glormph,項目名稱:kantele,代碼行數:12,代碼來源:jobs.py

示例6: store_ds_job

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
def store_ds_job(name, prejob_args, **kwargs):
    pjres = jobmap[name]['getfns'](*prejob_args)
    sf_ids = [x.id for x in pjres]
    jobargs = prejob_args + sf_ids
    job = Job(funcname=name, jobtype=jobmap[name]['type'],
              timestamp=timezone.now(),
              state=Jobstates.PENDING, args=json.dumps(jobargs),
              kwargs=json.dumps(kwargs))
    job.save()
    FileJob.objects.bulk_create([FileJob(storedfile_id=sf_id, job_id=job.id) for sf_id in sf_ids])
    return job
開發者ID:glormph,項目名稱:kantele,代碼行數:13,代碼來源:jobs.py

示例7: test_job_reaper_kills_old_jobs

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
 def test_job_reaper_kills_old_jobs(self):
     # make an old job:
     job = Job(job_name='counter')
     job.started = datetime.datetime.now() - timedelta(days=3)
     job.save()
     old_job_key = job.key()
     
     response = self.client.post(reverse('jobs.start'), {
         'job_name': 'counter'
     })
     json_response = simplejson.loads(response.content)
     self.assert_json_success(json_response)
     
     self.assertEqual(Job.get(old_job_key), None)
開發者ID:BubbleTouchSoftware,項目名稱:chirpradio,代碼行數:16,代碼來源:tests.py

示例8: test_saving_and_retrieving_jobs

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
    def test_saving_and_retrieving_jobs(self):
        first_job = Job()
        first_job.name = 'first_job_ever'
        first_job.save()

        second_job = Job()
        second_job.name = 'job_number_two'
        second_job.save()

        saved_jobs = Job.objects.all()
        self.assertEqual(saved_jobs.count(), 2)

        first_saved_job = saved_jobs[0]
        second_saved_job = saved_jobs[1]

        self.assertEqual(first_saved_job.name, 'first_job_ever')
        self.assertEqual(second_saved_job.name, 'job_number_two')
開發者ID:trbedwards,項目名稱:octodeps,代碼行數:19,代碼來源:tests.py

示例9: obj_update

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
 def obj_update(self, bundle, **kwargs):
     """
     Update to deactive mostly
     """
     try:
         if 'deactivate' in bundle.data.keys() and bundle.data['deactivate']:
             existing_job = Job.objects.get(id=bundle.data['job_id'])
             existing_job.deactivate = True
             existing_job.save()
             bundle.obj = existing_job
         else:
             company = Company.objects.get(id=bundle.data['company_id'])
             new_job = Job(name=bundle.data['name'], job_type=bundle.data['job_type'], location=bundle.data['location'], description=bundle.data['description'], company=company)
             new_job.save()
             bundle.obj = new_job
     except Exception, e:
         print e
         raise e
開發者ID:sanchitbareja,項目名稱:occuhunt-web,代碼行數:20,代碼來源:api.py

示例10: JobModelTest

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
class JobModelTest(TestCase):

    def setUp(self):
        self.job = Job()
        self.job.audit = AuditFactory()
        self.job.user = UserFactory()

    def test_jobs_can_be_created(self):
        self.job.full_clean()  # Should not raise
        self.job.save()        # Should not raise

    def test_job_initial_state(self):
        "Job initial state should be RECEIVED"
        self.assertEqual(self.job.state, Job.RECEIVED_STATE)

    def test_job_creation_timestamp(self):
        start = timezone.now()
        job = JobFactory()
        end = timezone.now()

        self.assertLessEqual(start, job.created_at)
        self.assertLessEqual(job.created_at, end)

    def test_job_report_url(self):
        "Fresh and unfinished jobs have no report file"
        job = JobFactory()
        with self.assertRaises(ValueError):
            job.report_file.url


    @patch('django.core.files.storage.default_storage._wrapped')
    def test_finished_job_report_url(self, storage_mock):
        file_mock = MagicMock(spec=File, name='FileMock')
        file_mock.name = 'test_file.txt'

        storage_mock.url = MagicMock('url')
        storage_mock.url.return_value = file_mock.name
        storage_mock.save.return_value = file_mock

        self.job.add_report(file_mock)

        self.assertEqual(self.job.report_file, file_mock)
        self.assertEqual(self.job.state, Job.SUCCESS_STATE)
開發者ID:tilacog,項目名稱:paranoid,代碼行數:45,代碼來源:test_models.py

示例11: obj_create

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
 def obj_create(self, bundle, **kwargs):
     """
     Create or delete a new job
     """
     print 1
     try:
         if 'deactivate' in bundle.data.keys() and bundle.data['deactivate']:
             print 2
             existing_job = Job.objects.get(id=bundle.data['job_id'])
             existing_job.deactivate = True
             existing_job.save()
             bundle.obj = existing_job
         else:
             print 3
             company = Company.objects.get(id=bundle.data['company_id'])
             new_job = Job(name=bundle.data['name'], job_type=bundle.data['job_type'], location=bundle.data['location'], description=bundle.data['description'], company=company)
             new_job.save()
             bundle.obj = new_job
     except Exception, e:
         print e
         raise e
開發者ID:sanchitbareja,項目名稱:occuhunt-web,代碼行數:23,代碼來源:api.py

示例12: publish

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
    def publish(self, request, pk=None):
        """
        use for draft job publish

        """
        draft_job = self.get_object()
        serializer = ActionSerializer(data=request.data)
        if serializer.is_valid():
            if serializer.data.pop('action') == AVAILABLE_ACTIONS['JOB_PUBLISH']:
                now = datetime.now().strftime('%Y%m%d%H%M%S%f') + '%s' % pk

                job_to_publish = Job()
                job_to_publish.owner = draft_job.owner
                job_to_publish.time_of_publish = timezone.now()
                job_to_publish.job_id = now
                job_to_publish.job_list_type = draft_job.job_list_type
                job_to_publish.status = Job.STATUS.active
                job_to_publish.job_rate = draft_job.job_rate
                job_to_publish.promotion_banner = draft_job.promotion_banner
                job_to_publish.title = draft_job.title
                job_to_publish.detail = draft_job.detail
                job_to_publish.time_of_release = draft_job.time_of_release
                job_to_publish.short_description = draft_job.short_description
                # if job_to_publish.support_image.all():
                #     for image in draft_job.support_image:
                #         SupportImage.objects.create(job=draft_job, image=image.image)
                support_image = SupportImage.objects.get(pk=draft_job.support_image.pk)
                support_image.pk = None
                support_image.save()
                job_to_publish.support_image = support_image
                job_to_publish.postal_code = draft_job.postal_code
                job_to_publish.keywords = draft_job.keywords
                job_to_publish.multiple_job_rates = draft_job.multiple_job_rates
                job_to_publish.save()
                return Response({'status': 'job published'})
            else:
                return Response({'status': 'action not supported'})
        else:
            return Response(serializer.errors,
                            status=status.HTTP_400_BAD_REQUEST)
開發者ID:frusciante,項目名稱:RestAPI,代碼行數:42,代碼來源:views.py

示例13: create

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
def create(request, create_form=CreateJobForm,
           template_name='jobs/create_form.html', success_url=None,
           extra_context=None):
	
	#profile = Profile.objects.get(user_id=request.user.id)
	#if profile and not(profile.if_employer):
	#	return render_to_response('jobs/index.html', {'form': form}, context_instance=RequestContext(request))

	form = create_form()

	if request.method == 'POST':
		form = create_form(request.POST, request.FILES)

		if form.is_valid():
			job = Job()
			job.user = request.user
			job.name = form.cleaned_data['name']
			job.location = form.cleaned_data['location']
			job.intern_project = form.cleaned_data['intern_project']
			job.save()

			# split by new line
			names_values = form.cleaned_data['names_values'].split('\n')
			# go trough all names and values
			for name_value in names_values:
				# skip extra spaces and split by first colon
				result = ' '.join(name_value.split()).split(":", 1)
				# when name and value
				if len(result) == 2:
					parameter = JobParameter()
					parameter.name = result[0].strip()
					parameter.value = result[1].strip()
					parameter.container = job
					parameter.save()

			return redirect('/jobs')
	return render_to_response('jobs/create_form.html', {'form': form}, context_instance=RequestContext(request))
開發者ID:nehulyadav,項目名稱:solesite,代碼行數:39,代碼來源:views.py

示例14: TestJob

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
class TestJob(TestCase):
    def setUp(self):
        self.client = Client()
        self.job = Job()
        self.job.position = "test"
        self.job.company_name = "company test"
        self.job.website = "pythonjobs.ie"
        self.job.category = "full"
        self.job.description = "Testing"
        self.job.email = "[email protected]"
        self.job.location = "Testing"
        self.job.save()

    def testDown(self):
        Job.objects.all().delete()

    def test_index_returns_200(self):
        response = self.client.get(reverse("job-home"))
        self.assertEquals(response.status_code, 200)

    def test_index_template(self):
        response = self.client.get("/")
        self.assertTemplateUsed(response, "index.html")

    def test_index_list_active_jobs(self):
        job = mommy.make(Job, status=0)
        response = self.client.get(reverse("job-home"))
        self.assertEquals(len(response.context["jobs"]), 1)

    def test_show_returns_200(self):
        response = self.client.get(reverse("job-show", args=[self.job.pk]))
        self.assertEquals(response.status_code, 200)

    def test_show_template(self):
        response = self.client.get(reverse("job-show", args=[self.job.pk]))
        self.assertTemplateUsed(response, "show.html")

    def test_new_returns_200(self):
        response = self.client.get(reverse("job-new"))
        self.assertEquals(response.status_code, 200)

    def test_new_template(self):
        response = self.client.get(reverse("job-new"))
        self.assertTemplateUsed(response, "new.html")

    def test_create_new_job(self):
        self.job.pk = 0
        params = model_to_dict(self.job)
        response = self.client.post(reverse("job-new"), params)
        self.assertEquals(response.status_code, 302)

    def test_edit_returns_200(self):
        response = self.client.get(reverse("job-edit", args=[self.job.token]))
        self.assertEquals(response.status_code, 200)

    def test_edit_template(self):
        response = self.client.get(reverse("job-edit", args=[self.job.token]))
        self.assertTemplateUsed(response, "edit.html")

    def test_feed_items_returns_not_empty_list(self):
        self.assertNotEqual(len(JobsFeed.items(self)), 0)

    def test_feed_title_returns_job_position(self):
        item = self.job
        self.assertEquals(JobsFeed.item_title(self, item), item.position)

    def test_feed_description_returns_job_description(self):
        feed_description = JobsFeed.item_description(self, self.job)
        self.assertEquals(feed_description, self.job.description)

    def test_feed_author_name_returns_job_pythonjobs_ie(self):
        feed_author = JobsFeed.item_author_name(self, self.job)
        self.assertEquals(feed_author, 'pythonjobs.ie')

    def test_feed_pubdate_returns_job_created_at(self):
        feed_pubdate = JobsFeed.item_pubdate(self, self.job)
        self.assertEquals(feed_pubdate, self.job.created_at)

    def test_feed_link_returns_job_link(self):
        job_link = reverse('job-show', args=[self.job.pk])
        self.assertEquals(JobsFeed.item_link(self, self.job), job_link)
開發者ID:jorgebg,項目名稱:pythonjobs.ie,代碼行數:83,代碼來源:test_views.py

示例15: TestJob

# 需要導入模塊: from jobs.models import Job [as 別名]
# 或者: from jobs.models.Job import save [as 別名]
class TestJob(TestCase):
    """
    Test cases for Job model
    """
    def setUp(self,):
        self.path = os.path.dirname(os.path.realpath(__file__))
        self.formats = ExportFormat.objects.all() #pre-loaded by 'insert_export_formats' migration
        Group.objects.create(name='TestDefaultExportExtentGroup')
        self.user = User.objects.create(username='demo', email='[email protected]', password='demo')
        bbox = Polygon.from_bbox((-7.96, 22.6, -8.14, 27.12))
        the_geom = GEOSGeometry(bbox, srid=4326)
        self.job = Job(name='TestJob',
                                 description='Test description', event='Nepal activation',
                                 user=self.user, the_geom=the_geom)
        self.job.save()
        self.uid = self.job.uid
        # add the formats to the job
        self.job.formats = self.formats
        self.job.save()
        self.tags = [('building','yes'), ('place','city'), ('highway','service'), ('aeroway','helipad')]
        for tag in self.tags:
            tag = Tag.objects.create(
                key = tag[0],
                value = tag[1],
                job = self.job
            )
    
    def test_job_creation(self,):
        saved_job = Job.objects.all()[0]
        self.assertEqual(self.job, saved_job)
        self.assertEquals(self.uid, saved_job.uid)
        self.assertIsNotNone(saved_job.created_at)
        self.assertIsNotNone(saved_job.updated_at)
        saved_formats = saved_job.formats.all()
        self.assertIsNotNone(saved_formats)
        self.assertItemsEqual(saved_formats, self.formats)
        tags = saved_job.tags.all()
        self.assertEquals(4, len(tags))
        self.assertEquals('Test description', saved_job.description)
        self.assertEquals(0, saved_job.configs.all().count())
        
    def test_job_creation_with_config(self,):
        saved_job = Job.objects.all()[0]
        self.assertEqual(self.job, saved_job)
        self.assertEquals(self.uid, saved_job.uid)
        self.assertIsNotNone(saved_job.created_at)
        self.assertIsNotNone(saved_job.updated_at)
        saved_formats = saved_job.formats.all()
        self.assertIsNotNone(saved_formats)
        self.assertItemsEqual(saved_formats, self.formats)
        # attach a configuration to a job
        f = File(open(self.path + '/files/hdm_presets.xml'))
        filename = f.name.split('/')[-1]
        config = ExportConfig.objects.create(name='Test Preset Config', filename=filename,
                                             upload=f, config_type='PRESET', user=self.user)
        f.close()
        self.assertIsNotNone(config)
        uid = config.uid
        saved_job.configs.add(config)
        saved_config = saved_job.configs.all()[0]
        self.assertEqual(config, saved_config)
        saved_config.delete() #cleanup
        
    def test_spatial_fields(self,):
        bbox = Polygon.from_bbox((-7.96, 22.6, -8.14, 27.12)) # in africa
        the_geom = GEOSGeometry(bbox, srid=4326)
        the_geog = GEOSGeometry(bbox)
        the_geom_webmercator = the_geom.transform(ct=3857, clone=True)
        job = Job.objects.all()[0]
        self.assertIsNotNone(job)
        geom = job.the_geom
        geog = job.the_geog
        geom_web = job.the_geom_webmercator
        self.assertEqual(the_geom, geom)
        self.assertEqual(the_geog, geog)
        self.assertEqual(the_geom_webmercator, geom_web)
        
    def test_fields(self, ):
        job = Job.objects.all()[0]
        self.assertEquals('TestJob', job.name)
        self.assertEquals('Test description', job.description)
        self.assertEquals('Nepal activation', job.event)
        self.assertEqual(self.user, job.user)
        
    def test_str(self, ):
        job = Job.objects.all()[0]
        self.assertEquals(str(job), 'TestJob')
        
    def test_job_region(self, ):
        bbox = Polygon.from_bbox((-7.96, 22.6, -8.14, 27.12)) # africa
        region = Region.objects.filter(the_geom__contains=bbox)[0]
        self.assertIsNotNone(region)
        self.assertEquals('Africa', region.name)
        self.job.region = region
        self.job.save()
        saved_job = Job.objects.all()[0]
        self.assertEqual(saved_job.region, region)
        
    def test_overpass_extents(self,):
        job = Job.objects.all()[0]
#.........這裏部分代碼省略.........
開發者ID:arushivashist,項目名稱:osm-export-tool2,代碼行數:103,代碼來源:test_models.py


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