def test_get_rest_flattened():
    client = RegionSslCertificatesClient(
        credentials=ga_credentials.AnonymousCredentials(), )

    # Mock the http request call within the method and fake a response.
    with mock.patch.object(Session, "request") as req:
        # Designate an appropriate value for the returned response.
        return_value = compute.SslCertificate()

        # Wrap the value into a proper Response obj
        json_return_value = compute.SslCertificate.to_json(return_value)
        response_value = Response()
        response_value.status_code = 200
        response_value._content = json_return_value.encode("UTF-8")
        req.return_value = response_value

        # Call the method with a truthy value for each flattened field,
        # using the keyword arguments to the method.
        client.get(
            project="project_value",
            region="region_value",
            ssl_certificate="ssl_certificate_value",
        )

        # Establish that the underlying call was made with the expected
        # request object values.
        assert len(req.mock_calls) == 1
        _, http_call, http_params = req.mock_calls[0]
        body = http_params.get("data")
        assert "project_value" in http_call[1] + str(body)
        assert "region_value" in http_call[1] + str(body)
        assert "ssl_certificate_value" in http_call[1] + str(body)
def test_get_rest_flattened_error():
    client = RegionSslCertificatesClient(
        credentials=ga_credentials.AnonymousCredentials(), )

    # Attempting to call a method with both a request object and flattened
    # fields is an error.
    with pytest.raises(ValueError):
        client.get(
            compute.GetRegionSslCertificateRequest(),
            project="project_value",
            region="region_value",
            ssl_certificate="ssl_certificate_value",
        )
def test_get_rest(transport: str = "rest",
                  request_type=compute.GetRegionSslCertificateRequest):
    client = RegionSslCertificatesClient(
        credentials=ga_credentials.AnonymousCredentials(),
        transport=transport,
    )

    # Everything is optional in proto3 as far as the runtime is concerned,
    # and we are mocking out the actual API, so just send an empty request.
    request = request_type()

    # Mock the http request call within the method and fake a response.
    with mock.patch.object(Session, "request") as req:
        # Designate an appropriate value for the returned response.
        return_value = compute.SslCertificate(
            certificate="certificate_value",
            creation_timestamp="creation_timestamp_value",
            description="description_value",
            expire_time="expire_time_value",
            id="id_value",
            kind="kind_value",
            managed=compute.SslCertificateManagedSslCertificate(
                domain_status={"key_value": "value_value"}),
            name="name_value",
            private_key="private_key_value",
            region="region_value",
            self_link="self_link_value",
            self_managed=compute.SslCertificateSelfManagedSslCertificate(
                certificate="certificate_value"),
            subject_alternative_names=["subject_alternative_names_value"],
            type_=compute.SslCertificate.Type.MANAGED,
        )

        # Wrap the value into a proper Response obj
        json_return_value = compute.SslCertificate.to_json(return_value)
        response_value = Response()
        response_value.status_code = 200
        response_value._content = json_return_value.encode("UTF-8")
        req.return_value = response_value
        response = client.get(request)

    # Establish that the response is the type that we expect.
    assert isinstance(response, compute.SslCertificate)
    assert response.certificate == "certificate_value"
    assert response.creation_timestamp == "creation_timestamp_value"
    assert response.description == "description_value"
    assert response.expire_time == "expire_time_value"
    assert response.id == "id_value"
    assert response.kind == "kind_value"
    assert response.managed == compute.SslCertificateManagedSslCertificate(
        domain_status={"key_value": "value_value"})
    assert response.name == "name_value"
    assert response.private_key == "private_key_value"
    assert response.region == "region_value"
    assert response.self_link == "self_link_value"
    assert response.self_managed == compute.SslCertificateSelfManagedSslCertificate(
        certificate="certificate_value")
    assert response.subject_alternative_names == [
        "subject_alternative_names_value"
    ]
    assert response.type_ == compute.SslCertificate.Type.MANAGED