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


Python responses.replace方法代碼示例

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


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

示例1: test_create_video_refresh_error

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_create_video_refresh_error(self) -> None:
        responses.add(
            responses.POST,
            "https://zoom.us/oauth/token",
            json={"access_token": "token", "expires_in": -60},
        )

        response = self.client_get(
            "/calls/zoom/complete",
            {"code": "code", "state": '{"realm":"zulip","sid":""}'},
        )
        self.assertEqual(response.status_code, 200)

        responses.replace(responses.POST, "https://zoom.us/oauth/token", status=400)

        response = self.client_post("/json/calls/zoom/create")
        self.assert_json_error(response, "Invalid Zoom access token") 
開發者ID:zulip,項目名稱:zulip,代碼行數:19,代碼來源:test_create_video_call.py

示例2: test_bad_oss_licenses

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_bad_oss_licenses(self):
        """ Test when is not possible to retrieve the supported OSS license list from Bintray.
            The hook must stop when is not possible to request OSS licenses.
        """
        responses.replace(responses.GET, "https://api.bintray.com/licenses/oss_licenses", status=500, json={"message": "You have reached a dark spot"})
        tools.save('conanfile.py', content=self.conanfile_complete)
        self.conan(['export', '.', 'dummy/0.1.0@foobar/stable'])
        output = self.conan(['upload', '--remote=fake', 'dummy/0.1.0@foobar/stable'])
        self.assertIn("Uploading dummy/0.1.0@foobar/stable to remote 'fake'", output)
        self.assertIn("Uploaded conan recipe 'dummy/0.1.0@foobar/stable' to 'fake'", output)
        self.assertIn("post_upload_recipe(): Reading package info from Bintray.", output)
        self.assertIn("post_upload_recipe(): Inspecting recipe info.", output)
        self.assertIn('post_upload_recipe(): ERROR: Could not request OSS licenses. This hook ' \
                      'requires access to OSS license list in Bintray (URL), you may deactivate ' \
                      'the hook if the situation persists. Error (500): {"message": "You have ' \
                      'reached a dark spot"}', output) 
開發者ID:conan-io,項目名稱:hooks,代碼行數:18,代碼來源:test_bintray_updater.py

示例3: test_bad_patch_package_info

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_bad_patch_package_info(self):
        """ Test bad request when patching the package information on Bintray.
            The hook must not continue when is not possible to patch the information.
        """
        responses.replace(responses.PATCH, "https://api.bintray.com/packages/foobar/conan/dummy%3Afoobar", status=500, json={"message": "You have reached a dark spot"})
        tools.save('conanfile.py', content=self.conanfile_complete)
        self.conan(['export', '.', 'dummy/0.1.0@foobar/stable'])
        output = self.conan(['upload', '--remote=fake', 'dummy/0.1.0@foobar/stable'])
        self.assertIn("Uploading dummy/0.1.0@foobar/stable to remote 'fake'", output)
        self.assertIn("Uploaded conan recipe 'dummy/0.1.0@foobar/stable' to 'fake': https://bintray.com/foobar/conan", output)
        self.assertIn("post_upload_recipe(): Reading package info from Bintray.", output)
        self.assertIn("post_upload_recipe(): Inspecting recipe info.", output)
        self.assertIn("post_upload_recipe(): Bintray is outdated. Updating Bintray package info:" \
                      " 'desc', 'github_repo', 'issue_tracker_url', 'labels', 'licenses', " \
                      "'vcs_url', 'website_url'.", output)
        self.assertIn('post_upload_recipe(): ERROR: Could not patch package info: {"message": "You have reached a dark spot"}', output)
        self.assertNotIn("post_upload_recipe(): Bintray package information has been updated with success.", output) 
開發者ID:conan-io,項目名稱:hooks,代碼行數:19,代碼來源:test_bintray_updater.py

示例4: test_up_to_date_info

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_up_to_date_info(self):
        """ Do not update when the information is up-to-date.
            The hook must not patch when there is no different between local recipe and remote info.
        """
        information = {
            "desc": "This a dummy library",
            "labels":["conan", "dummy", "qux", "baz"],
            "licenses":["MIT"],
            "website_url": "https://dummy.org",
            "issue_tracker_url":"https://github.com/foobar/community/issues",
            "vcs_url":"https://github.com/foobar/conan-dummy",
            "github_repo": "foobar/conan-dummy",
            "maturity":"Stable"
        }
        responses.replace(responses.GET, 'https://api.bintray.com/packages/foobar/conan/dummy%3Afoobar', json=information)
        tools.save('conanfile.py', content=self.conanfile_complete)
        self.conan(['export', '.', 'dummy/0.1.0@foobar/stable'])
        output = self.conan(['upload', '--remote=fake', 'dummy/0.1.0@foobar/stable'])
        self.assertIn("Uploading dummy/0.1.0@foobar/stable to remote 'fake'", output)
        self.assertIn("Uploaded conan recipe 'dummy/0.1.0@foobar/stable' to 'fake': https://bintray.com/foobar/conan", output)
        self.assertIn("post_upload_recipe(): Reading package info from Bintray.", output)
        self.assertIn("post_upload_recipe(): Inspecting recipe info.", output)
        self.assertNotIn("post_upload_recipe(): Bintray is outdated.", output)
        self.assertIn("post_upload_recipe(): Bintray package info is up-to-date.", output)
        self.assertNotIn("post_upload_recipe(): Bintray package information has been updated with success.", output) 
開發者ID:conan-io,項目名稱:hooks,代碼行數:27,代碼來源:test_bintray_updater.py

示例5: test_create_video_request_success

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_create_video_request_success(self) -> None:
        responses.add(
            responses.POST,
            "https://zoom.us/oauth/token",
            json={"access_token": "oldtoken", "expires_in": -60},
        )

        response = self.client_get(
            "/calls/zoom/complete",
            {"code": "code", "state": '{"realm":"zulip","sid":""}'},
        )
        self.assertEqual(response.status_code, 200)

        responses.replace(
            responses.POST,
            "https://zoom.us/oauth/token",
            json={"access_token": "newtoken", "expires_in": 60},
        )

        responses.add(
            responses.POST,
            "https://api.zoom.us/v2/users/me/meetings",
            json={"join_url": "example.com"},
        )

        response = self.client_post("/json/calls/zoom/create")
        self.assertEqual(
            responses.calls[-1].request.url, "https://api.zoom.us/v2/users/me/meetings",
        )
        self.assertEqual(
            responses.calls[-1].request.headers["Authorization"], "Bearer newtoken",
        )
        json = self.assert_json_success(response)
        self.assertEqual(json["url"], "example.com")

        self.logout()
        self.login_user(self.user)

        response = self.client_post("/json/calls/zoom/create")
        self.assert_json_error(response, "Invalid Zoom access token") 
開發者ID:zulip,項目名稱:zulip,代碼行數:42,代碼來源:test_create_video_call.py

示例6: test_create_video_request_error

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_create_video_request_error(self) -> None:
        responses.add(
            responses.POST,
            "https://zoom.us/oauth/token",
            json={"access_token": "token"},
        )

        responses.add(
            responses.POST, "https://api.zoom.us/v2/users/me/meetings", status=400,
        )

        response = self.client_get(
            "/calls/zoom/complete",
            {"code": "code", "state": '{"realm":"zulip","sid":""}'},
        )
        self.assertEqual(response.status_code, 200)

        response = self.client_post("/json/calls/zoom/create")
        self.assert_json_error(response, "Failed to create Zoom call")

        responses.replace(
            responses.POST, "https://api.zoom.us/v2/users/me/meetings", status=401,
        )

        response = self.client_post("/json/calls/zoom/create")
        self.assert_json_error(response, "Invalid Zoom access token") 
開發者ID:zulip,項目名稱:zulip,代碼行數:28,代碼來源:test_create_video_call.py

示例7: test_get_display_name

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_get_display_name(self, user, room):
        displayname_url = HOSTNAME + MATRIX_V2_API_PATH + \
            "/profile/{}/displayname".format(user.user_id)
        displayname = 'test'
        room_displayname = 'room_test'

        # No displayname
        assert user.get_display_name(room) == user.user_id
        responses.add(responses.GET, displayname_url, json={})
        assert user.get_display_name() == user.user_id
        assert len(responses.calls) == 1

        # Get global displayname
        responses.replace(responses.GET, displayname_url,
                          json={"displayname": displayname})
        assert user.get_display_name() == displayname
        assert len(responses.calls) == 2

        # Global displayname already present
        assert user.get_display_name() == displayname
        # No new request
        assert len(responses.calls) == 2

        # Per-room displayname
        room.members_displaynames[user.user_id] = room_displayname
        assert user.get_display_name(room) == room_displayname
        # No new request
        assert len(responses.calls) == 2 
開發者ID:saadnpq,項目名稱:matrixcli,代碼行數:30,代碼來源:user_test.py

示例8: accept_conan_upload

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def accept_conan_upload(func):
    """ Decorator to replace remote URLs
    :param func: Wrapped function
    """
    def wrapper(*args, **kwargs):
        empty_package_response = {
            "desc":None,
            "labels":[],
            "licenses":[],
            "website_url":None,
            "issue_tracker_url":None,
            "github_repo":None,
            "vcs_url":None,
            "maturity":""
        }
        oss_licenses = [{
            "name": "MIT",
            "longname": "The MIT License",
            "url": "http://www.opensource.org/licenses/mit-license.php"
        }, {
            "name": "BSD 2-Clause",
            "longname": "Berkeley Software Distribution Simplified (BSD Simplified)",
            "url": "http://opensource.org/licenses/BSD-2-Clause"
        }]
        responses.add(responses.GET, 'https://api.bintray.com/conan/foobar/conan/v1/ping')
        responses.add(responses.GET, 'https://api.bintray.com/conan/foobar/conan/v1/conans/dummy/0.1.0/foobar/stable/digest', json={"conanmanifest.txt":""})
        responses.add(responses.GET, 'https://api.bintray.com/conan/foobar/conan', status=404)
        responses.add(responses.GET, 'https://api.bintray.com/conan/foobar/conan/v1/users/check_credentials')
        responses.add(responses.GET, 'https://api.bintray.com/conan/foobar/conan/v1/conans/dummy/0.1.0/foobar/stable', json={})
        responses.add(responses.POST, 'https://api.bintray.com/conan/foobar/conan/v1/conans/dummy/0.1.0/foobar/stable/upload_urls', json={})
        responses.add(responses.GET, "https://api.bintray.com/licenses/oss_licenses", json=oss_licenses)
        responses.add(responses.PATCH, "https://api.bintray.com/packages/foobar/conan/dummy%3Afoobar", json={})
        responses.add(responses.GET, 'https://api.bintray.com/packages/foobar/conan/dummy%3Afoobar', json=empty_package_response)
        func(*args, **kwargs)
    return wrapper 
開發者ID:conan-io,項目名稱:hooks,代碼行數:37,代碼來源:test_bintray_updater.py

示例9: test_bad_package_info_request

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_bad_package_info_request(self):
        """ Test bad request when retrieving package information from Bintray.
            The hook must not continue when is not possible to retrieve the cached information.
        """
        responses.replace(responses.GET, 'https://api.bintray.com/packages/foobar/conan/dummy%3Afoobar', status=500, json={"message": "You have reached a dark spot"})
        tools.save('conanfile.py', content=self.conanfile_complete)
        self.conan(['export', '.', 'dummy/0.1.0@foobar/stable'])
        output = self.conan(['upload', '--remote=fake', 'dummy/0.1.0@foobar/stable'])
        self.assertIn("Uploading dummy/0.1.0@foobar/stable to remote 'fake'", output)
        self.assertIn("Uploaded conan recipe 'dummy/0.1.0@foobar/stable' to 'fake': https://bintray.com/foobar/conan", output)
        self.assertIn("post_upload_recipe(): Reading package info from Bintray.", output)
        self.assertIn('ERROR: Could not request package info (500): {"message": "You have reached a dark spot"}', output)
        self.assertNotIn("post_upload_recipe(): Inspecting recipe info.", output) 
開發者ID:conan-io,項目名稱:hooks,代碼行數:15,代碼來源:test_bintray_updater.py

示例10: test_push_tracks_to_lms

# 需要導入模塊: import responses [as 別名]
# 或者: from responses import replace [as 別名]
def test_push_tracks_to_lms(self):
        """
        Verify that we notify the LMS about tracks without seats on a save() to reviewed
        """
        self.partner.lms_url = 'http://127.0.0.1:8000'
        self.partner.save()
        self.mock_access_token()
        self.mock_ecommerce_publication()
        url = '{root}courses/{key}/'.format(root=self.partner.lms_coursemode_api_url, key=self.course_run.key)

        # Mark course as draft
        self.course_run.course.draft = True
        self.course_run.course.save()

        # Set up and save run
        self.course_run.type = factories.CourseRunTypeFactory(
            tracks=[
                factories.TrackFactory(mode__slug='no-seat', seat_type=None),
                factories.TrackFactory(mode__slug='has-seat'),
            ],
        )
        self.course_run.draft = True
        self.course_run.status = CourseRunStatus.Reviewed

        responses.add(responses.GET, url, json=[], status=200)
        responses.add(responses.POST, url, json={}, status=201)
        with LogCapture(utils_logger.name) as log_capture:
            self.course_run.save()
            log_capture.check_present((utils_logger.name, 'INFO',
                                      'Successfully published [no-seat] LMS mode for [%s].' % self.course_run.key))

        # Test that we don't re-publish modes
        self.course_run.status = CourseRunStatus.Unpublished
        self.course_run.save()
        self.course_run.status = CourseRunStatus.Reviewed
        responses.replace(responses.GET, url, json=[{'mode_slug': 'no-seat'}], status=200)
        with LogCapture(utils_logger.name) as log_capture:
            self.course_run.save()
            log_capture.check()  # no messages at all, we skipped sending

        # Test we report failures
        self.course_run.status = CourseRunStatus.Unpublished
        self.course_run.save()
        self.course_run.status = CourseRunStatus.Reviewed
        responses.replace(responses.GET, url, json=[], status=200)
        responses.replace(responses.POST, url, body='Shrug', status=500)
        with LogCapture(utils_logger.name) as log_capture:
            self.course_run.save()
            log_capture.check_present((utils_logger.name, 'WARNING',
                                      'Failed publishing [no-seat] LMS mode for [%s]: Shrug' % self.course_run.key)) 
開發者ID:edx,項目名稱:course-discovery,代碼行數:52,代碼來源:test_models.py


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