OIDTokenRequest+Testing.m 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // Copyright 2021 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #import "GoogleSignIn/Tests/Unit/OIDTokenRequest+Testing.h"
  15. #import "GoogleSignIn/Tests/Unit/OIDAuthorizationResponse+Testing.h"
  16. #ifdef SWIFT_PACKAGE
  17. @import AppAuth;
  18. #else
  19. #import <AppAuth/OIDAuthorizationRequest.h>
  20. #import <AppAuth/OIDScopeUtilities.h>
  21. #endif
  22. @implementation OIDTokenRequest (Testing)
  23. + (instancetype)testInstance {
  24. return [self testInstanceWithAdditionalParameters:nil];
  25. }
  26. + (instancetype)testInstanceWithAdditionalParameters:
  27. (NSDictionary<NSString *, NSString *> *)additionalParameters {
  28. OIDAuthorizationResponse *authorizationResponse = [OIDAuthorizationResponse testInstance];
  29. OIDAuthorizationRequest *authorizationRequest = authorizationResponse.request;
  30. return [[OIDTokenRequest alloc]
  31. initWithConfiguration:authorizationResponse.request.configuration
  32. grantType:OIDGrantTypeAuthorizationCode
  33. authorizationCode:authorizationResponse.authorizationCode
  34. redirectURL:authorizationRequest.redirectURL
  35. clientID:authorizationRequest.clientID
  36. clientSecret:authorizationRequest.clientID
  37. scopes:[OIDScopeUtilities scopesArrayWithString:authorizationRequest.scope]
  38. refreshToken:@"refreshToken"
  39. codeVerifier:authorizationRequest.codeVerifier
  40. additionalParameters:additionalParameters];
  41. }
  42. @end