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


Python App.door43_s3_handler方法代碼示例

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


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

示例1: test_obs_deploy_revision_to_door43

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
 def test_obs_deploy_revision_to_door43(self):
     self.mock_s3_obs_project()
     build_log_key = '{0}/build_log.json'.format(self.project_key)
     ret = self.deployer.deploy_revision_to_door43(build_log_key)
     self.assertTrue(ret)
     self.assertTrue(App.door43_s3_handler().key_exists(build_log_key))
     self.assertTrue(App.door43_s3_handler().key_exists('{0}/50.html'.format(self.project_key)))
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:9,代碼來源:test_project_deployer.py

示例2: multipart_master_merge

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
 def multipart_master_merge(self, s3_commit_key, resource_type, download_key, output_dir, source_dir, start,
                            template_file):
     prefix = download_key + '/'
     App.door43_s3_handler().download_dir(prefix, source_dir)  # get previous templated files
     source_dir = os.path.join(source_dir, download_key)
     files = sorted(glob(os.path.join(source_dir, '*.*')))
     for f in files:
         App.logger.debug("Downloaded: " + f)
     fname = os.path.join(source_dir, 'index.html')
     if os.path.isfile(fname):
         os.remove(fname)  # remove index if already exists
     elapsed_seconds = int(time.time() - start)
     App.logger.debug("deploy download completed in " + str(elapsed_seconds) + " seconds")
     templater = init_template(resource_type, source_dir, output_dir, template_file)
     # restore index from previous passes
     index_json = self.get_templater_index(s3_commit_key, 'index.json')
     templater.titles = index_json['titles']
     templater.chapters = index_json['chapters']
     templater.book_codes = index_json['book_codes']
     templater.already_converted = templater.files  # do not reconvert files
     # merge the source files with the template
     try:
         self.run_templater(templater)
         success = True
     except Exception as e:
         App.logger.error("Error multi-part applying template {0} to resource type {1}".format(template_file,
                                                                                               resource_type))
         self.close()
         success = False
     return source_dir, success
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:32,代碼來源:project_deployer.py

示例3: mock_s3_bible_project

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
    def mock_s3_bible_project(self, test_file_name, project_key, multi_part=False):
        converted_proj_dir = os.path.join(self.resources_dir, 'converted_projects')
        test_file_base = test_file_name.split('.zip')[0]
        zip_file = os.path.join(converted_proj_dir, test_file_name)
        out_dir = os.path.join(self.temp_dir, test_file_base)
        unzip(zip_file, out_dir)
        project_dir = os.path.join(out_dir, test_file_base) + os.path.sep
        self.project_files = file_utils.get_files(out_dir)
        self.project_key = project_key
        for filename in self.project_files:
            sub_path = filename.split(project_dir)[1].replace(os.path.sep, '/')  # Make sure it is a bucket path
            App.cdn_s3_handler().upload_file(filename, '{0}/{1}'.format(project_key, sub_path))

            if multi_part:  # copy files from cdn to door43
                base_name = os.path.basename(filename)
                if '.html' in base_name:
                    with codecs.open(filename, 'r', 'utf-8-sig') as f:
                        soup = BeautifulSoup(f, 'html.parser')

                    # add nav tag
                    new_tag = soup.new_tag('div', id='right-sidebar')
                    soup.body.append(new_tag)
                    html = unicode(soup)
                    file_utils.write_file(filename, html.encode('ascii', 'xmlcharrefreplace'))

                App.door43_s3_handler().upload_file(filename, '{0}/{1}'.format(project_key, base_name))

        # u, user, repo = project_key
        App.door43_s3_handler().upload_file(os.path.join(self.resources_dir, 'templates', 'project-page.html'),
                                          'templates/project-page.html')
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:32,代碼來源:test_project_deployer.py

示例4: test_tw_deploy_revision_to_door43

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
 def test_tw_deploy_revision_to_door43(self):
     self.mock_s3_tw_project()
     build_log_key = '{0}/build_log.json'.format(self.project_key)
     ret = self.deployer.deploy_revision_to_door43(build_log_key)
     self.assertTrue(ret)
     self.assertTrue(App.door43_s3_handler().key_exists(build_log_key))
     for file_name in ['index.html', 'kt.html', 'names.html', 'other.html', 'build_log.json', 'manifest.yaml']:
         key = '{0}/{1}'.format(self.project_key, file_name)
         self.assertTrue(App.door43_s3_handler().key_exists(key), "Key not found: {0}".format(key))
     parent_key = '/'.join(self.project_key.split('/')[:-1])
     for file_name in ['project.json']:
         key = '{0}/{1}'.format(parent_key, file_name)
         self.assertTrue(App.door43_s3_handler().key_exists(key), "Key not found: {0}".format(key))
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:15,代碼來源:test_project_deployer.py

示例5: mock_s3_obs_project

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
 def mock_s3_obs_project(self):
     zip_file = os.path.join(self.resources_dir, 'converted_projects', 'en-obs-complete.zip')
     out_dir = os.path.join(self.temp_dir, 'en-obs-complete')
     unzip(zip_file, out_dir)
     project_dir = os.path.join(out_dir, 'door43', 'en-obs', '12345678')
     self.project_files = [f for f in os.listdir(project_dir) if os.path.isfile(os.path.join(project_dir, f))]
     self.project_key = 'u/door43/en-obs/12345678'
     for filename in self.project_files:
         App.cdn_s3_handler().upload_file(os.path.join(project_dir, filename), '{0}/{1}'.format(self.project_key,
                                                                                                filename))
     App.cdn_s3_handler().upload_file(os.path.join(out_dir, 'door43', 'en-obs', 'project.json'),
                                      'u/door43/en-obs/project.json')
     App.door43_s3_handler().upload_file(os.path.join(self.resources_dir, 'templates', 'project-page.html'),
                                         'templates/project-page.html')
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:16,代碼來源:test_project_deployer.py

示例6: setUp

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
 def setUp(self):
     """Runs before each test."""
     App(prefix='{0}-'.format(self._testMethodName))
     App.cdn_s3_handler().create_bucket()
     App.door43_s3_handler().create_bucket()
     self.temp_dir = tempfile.mkdtemp(prefix="test_project_deployer")
     self.deployer = ProjectDeployer()
     TdLanguage.language_list = {
         'aa': TdLanguage({'gw': False, 'ld': 'ltr', 'ang': 'Afar', 'lc': 'aa', 'ln': 'Afaraf', 'lr': 'Africa',
                           'pk': 6}),
         'en': TdLanguage({'gw': True, 'ld': 'ltr', 'ang': 'English', 'lc': 'en', 'ln': 'English',
                           'lr': 'Europe', 'pk': 1747}),
         'es': TdLanguage({'gw': True, 'ld': 'ltr', 'ang': 'Spanish', 'lc': 'es', 'ln': 'espa\xf1ol',
                           'lr': 'Europe', 'pk': 1776}),
         'fr': TdLanguage({'gw': True, 'ld': 'ltr', 'ang': 'French', 'lc': 'fr',
                           'ln': 'fran\xe7ais, langue fran\xe7aise', 'lr': 'Europe', 'pk': 1868})
     }
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:19,代碼來源:test_project_deployer.py

示例7: test_tn_deploy_revision_to_door43

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
    def test_tn_deploy_revision_to_door43(self):
        # given
        part = '1'
        self.mock_s3_tn_project(part)
        build_log_key = '{0}/{1}/build_log.json'.format(self.project_key, part)

        # when
        ret = self.deployer.deploy_revision_to_door43(build_log_key)

        # then
        self.assertTrue(ret)
        self.assertTrue(App.door43_s3_handler().key_exists('{0}/build_log.json'.format(self.project_key)))
        files_to_verify = ['01-GEN.html', 'index.json']

        for file_name in files_to_verify:
            key = '{0}/{1}'.format(self.project_key, file_name)
            self.assertTrue(App.door43_s3_handler().key_exists(key), "Key not found: {0}".format(key))
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:19,代碼來源:test_project_deployer.py

示例8: validate_conversion

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
    def validate_conversion(self, user, repo, success, build_log_json, commit_id, commit_sha, commit_path,
                            expected_output_names, job, chapter_count=-1, file_ext=""):
        self.assertTrue(len(build_log_json) > 0)
        self.assertIsNotNone(job)
        self.temp_dir = tempfile.mkdtemp(prefix='testing_')

        if not (type(expected_output_names) is list):
            expected_output_names = [expected_output_names]  # put string in list

        # check pre-convert files
        self.download_and_check_zip_file(self.preconvert_handler, expected_output_names,
                                         self.preprocessor_output_extension, self.get_preconvert_s3_key(commit_sha),
                                         "preconvert", success, chapter_count, file_ext)

        # check converted files
        destination_key = self.get_destination_s3_key(commit_sha, repo, user)
        converted_build_log = self.check_destination_files(self.cdn_handler, expected_output_names, "html",
                                                           destination_key, chapter_count)

        # check required fields
        App.logger.debug(converted_build_log)
        saved_build_json = json.loads(converted_build_log)
        self.assertTrue('commit_id' in saved_build_json)
        self.assertTrue('repo_owner' in saved_build_json)
        self.assertTrue('repo_name' in saved_build_json)
        self.assertTrue('created_at' in saved_build_json)
        self.assertTrue('source' in saved_build_json)
        self.assertTrue('errors' in saved_build_json)
        self.assertTrue('warnings' in saved_build_json)
        self.assertTrue('message' in saved_build_json)
        self.assertTrue('status' in saved_build_json)

        self.assertEqual(len(commit_id), COMMIT_LENGTH)
        self.assertIsNotNone(commit_sha)
        self.assertIsNotNone(commit_path)
        if len(job.errors) > 0:
            self.warn("WARNING: Found job errors: " + str(job.errors))

        if len(build_log_json['errors']) > 0:
            self.warn("WARNING: Found build_log errors: " + str(build_log_json['errors']))

        door43_handler = App.door43_s3_handler()
        deployed_build_log = self.check_deployed_files(door43_handler, expected_output_names, "html",
                                                       destination_key, chapter_count)

        self.compare_build_logs(converted_build_log, deployed_build_log, destination_key)

        if len(self.warnings):
            App.logger.debug("\n#######\nHave warnings:\n#######\n" + '\n'.join(self.warnings))

        self.assertTrue(success)

        # Test that repo is in manifest table
        tx_manifest = TxManifest.get(repo_name=repo, user_name=user)
        # Giving TxManifest above just the composite keys will cause it to load all the data from the App.
        self.assertIsNotNone(tx_manifest)
        self.assertEqual(tx_manifest.repo_name, repo)
        self.assertEqual(tx_manifest.user_name, user)
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:60,代碼來源:test_conversion.py

示例9: mock_s3_tn_project

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
 def mock_s3_tn_project(self, part):
     zip_file = os.path.join(self.resources_dir, 'converted_projects', 'en_tn_converted.zip')
     out_dir = os.path.join(self.temp_dir, 'en_tn_converted')
     unzip(zip_file, out_dir)
     src_dir = os.path.join(out_dir, 'en_tn_converted')
     self.project_files = [f for f in os.listdir(src_dir) if os.path.isfile(os.path.join(src_dir, f))]
     self.project_key = 'u/door43/en_tn/12345678'
     build_log = file_utils.load_json_object(os.path.join(src_dir, 'build_log.json'))
     build_log['part'] = part
     file_utils.write_file(os.path.join(src_dir, 'build_log.json'), build_log)
     App.cdn_s3_handler().upload_file(os.path.join(src_dir, 'build_log.json'),
                                      '{0}/{1}/build_log.json'.format(self.project_key, part))
     App.cdn_s3_handler().upload_file(os.path.join(src_dir, 'index.json'),
                                      '{0}/{1}/index.json'.format(self.project_key, part))
     App.cdn_s3_handler().upload_file(os.path.join(src_dir, 'build_log.json'),
                                      '{0}/{1}/finished'.format(self.project_key, part))
     App.cdn_s3_handler().upload_file(os.path.join(src_dir, '01-GEN.html'),
                                      '{0}/{1}/01-GEN.html'.format(self.project_key, part))
     App.cdn_s3_handler().upload_file(os.path.join(src_dir, 'project.json'),
                                      'u/door43/en_tq/project.json')
     App.door43_s3_handler().upload_file(os.path.join(self.resources_dir, 'templates', 'project-page.html'),
                                         'templates/project-page.html')
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:24,代碼來源:test_project_deployer.py

示例10: test_tq_deploy_revision_to_door43

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
    def test_tq_deploy_revision_to_door43(self):
        # given
        self.mock_s3_tq_project()
        build_log_key = '{0}/build_log.json'.format(self.project_key)

        # when
        ret = self.deployer.deploy_revision_to_door43(build_log_key)

        # then
        self.assertTrue(ret)
        self.assertTrue(App.door43_s3_handler().key_exists(build_log_key))
        files_to_verify = ['manifest.yaml']
        for book in BOOK_NUMBERS:
            html_file = '{0}-{1}.html'.format(BOOK_NUMBERS[book], book.upper())
            files_to_verify.append(html_file)

        for file_name in files_to_verify:
            key = '{0}/{1}'.format(self.project_key, file_name)
            self.assertTrue(App.door43_s3_handler().key_exists(key), "Key not found: {0}".format(key))
        parent_key = '/'.join(self.project_key.split('/')[:-1])
        for file_name in ['project.json']:
            key = '{0}/{1}'.format(parent_key, file_name)
            self.assertTrue(App.door43_s3_handler().key_exists(key), "Key not found: {0}".format(key))
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:25,代碼來源:test_project_deployer.py

示例11: validate_bible_results

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
 def validate_bible_results(self, ret, build_log_key, expect_success, output_key):
     self.assertEqual(ret, expect_success)
     if expect_success:
         if output_key:
             self.assertTrue(App.door43_s3_handler().key_exists(output_key))
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:7,代碼來源:test_project_deployer.py

示例12: deploy_revision_to_door43

# 需要導入模塊: from libraries.app.app import App [as 別名]
# 或者: from libraries.app.app.App import door43_s3_handler [as 別名]
    def deploy_revision_to_door43(self, build_log_key):
        """
        Deploys a single revision of a project to door43.org
        :param string build_log_key:
        :return bool:
        """
        build_log = None
        try:
            build_log = App.cdn_s3_handler().get_json(build_log_key, catch_exception=False)
        except Exception as e:
            App.logger.debug("Deploying error could not access {0}: {1}".format(build_log_key, str(e)))
            pass

        if not build_log or 'commit_id' not in build_log or 'repo_owner' not in build_log \
                or 'repo_name' not in build_log:
            App.logger.debug("Exiting, Invalid build log at {0}: {1}".format(build_log_key, build_log))
            return False

        start = time.time()
        App.logger.debug("Deploying, build log: " + json.dumps(build_log)[:256])

        user = build_log['repo_owner']
        repo_name = build_log['repo_name']
        commit_id = build_log['commit_id'][:10]

        s3_commit_key = 'u/{0}/{1}/{2}'.format(user, repo_name, commit_id)
        s3_repo_key = 'u/{0}/{1}'.format(user, repo_name)
        download_key = s3_commit_key

        do_part_template_only = False
        do_multipart_merge = False
        if 'multiple' in build_log:
            do_multipart_merge = build_log['multiple']
            App.logger.debug("Found multi-part merge: {0}".format(download_key))

            prefix = download_key + '/'
            undeployed = self.get_undeployed_parts(prefix)
            if len(undeployed) > 0:
                App.logger.debug("Exiting, Parts not yet deployed: {0}".format(undeployed))
                return False

            key_deployed_ = download_key + '/final_deployed'
            if App.cdn_s3_handler().key_exists(key_deployed_):
                App.logger.debug("Exiting, Already merged parts: {0}".format(download_key))
                return False
            self.write_data_to_file(self.temp_dir, key_deployed_, 'final_deployed', ' ')  # flag that deploy has begun
            App.logger.debug("Continuing with merge: {0}".format(download_key))

        elif 'part' in build_log:
            part = build_log['part']
            download_key += '/' + part
            do_part_template_only = True
            App.logger.debug("Found partial: {0}".format(download_key))

            if not App.cdn_s3_handler().key_exists(download_key + '/finished'):
                App.logger.debug("Exiting, Not ready to process partial")
                return False

        source_dir = tempfile.mkdtemp(prefix='source_', dir=self.temp_dir)
        output_dir = tempfile.mkdtemp(prefix='output_', dir=self.temp_dir)
        template_dir = tempfile.mkdtemp(prefix='template_', dir=self.temp_dir)

        resource_type = build_log['resource_type']
        template_key = 'templates/project-page.html'
        template_file = os.path.join(template_dir, 'project-page.html')
        App.logger.debug("Downloading {0} to {1}...".format(template_key, template_file))
        App.door43_s3_handler().download_file(template_key, template_file)

        if not do_multipart_merge:
            source_dir, success = self.template_converted_files(build_log, download_key, output_dir, repo_name,
                                                                resource_type, s3_commit_key, source_dir, start,
                                                                template_file)
            if not success:
                return False
        else:
            source_dir, success = self.multipart_master_merge(s3_commit_key, resource_type, download_key, output_dir,
                                                              source_dir, start, template_file)
            if not success:
                return False

        #######################
        #
        #  Now do the deploy
        #
        #######################

        if not do_part_template_only or do_multipart_merge:
            # Copy first HTML file to index.html if index.html doesn't exist
            html_files = sorted(glob(os.path.join(output_dir, '*.html')))
            index_file = os.path.join(output_dir, 'index.html')
            if len(html_files) > 0 and not os.path.isfile(index_file):
                copyfile(os.path.join(output_dir, html_files[0]), index_file)

        # Copy all other files over that don't already exist in output_dir, like css files
        for filename in sorted(glob(os.path.join(source_dir, '*'))):
            output_file = os.path.join(output_dir, os.path.basename(filename))
            if not os.path.exists(output_file) and not os.path.isdir(filename):
                copyfile(filename, output_file)

            if do_part_template_only:  # move files to common area
#.........這裏部分代碼省略.........
開發者ID:unfoldingWord-dev,項目名稱:tx-manager,代碼行數:103,代碼來源:project_deployer.py


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