FPRHermeticTestServer.h 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. // Copyright 2020 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 <Foundation/Foundation.h>
  15. #if SWIFT_PACKAGE
  16. #import "GCDWebServer.h"
  17. #import "GCDWebServerDataResponse.h"
  18. #import "GCDWebServerFileResponse.h"
  19. #else
  20. #import <GCDWebServer/GCDWebServer.h>
  21. #import <GCDWebServer/GCDWebServerDataResponse.h>
  22. #import <GCDWebServer/GCDWebServerFileResponse.h>
  23. #endif
  24. NS_ASSUME_NONNULL_BEGIN
  25. @class GCDWebServerRequest;
  26. @class GCDWebServerResponse;
  27. /** This class provides a hermetic test service that runs on the device/simulator. */
  28. @interface FPRHermeticTestServer : NSObject
  29. /** The URL of the server. */
  30. @property(nonatomic, readonly) NSURL *serverURL;
  31. /** The block that will be invoked when the server sets lastResponse. Responses should be handled
  32. * as they normally would be, and this block just used for verification or timing.
  33. */
  34. @property(nonatomic, copy, nullable) void (^responseCompletedBlock)
  35. (GCDWebServerRequest *request, GCDWebServerResponse *response);
  36. /** Registers the paths used for testing. */
  37. - (void)registerTestPaths;
  38. /** Starts the server. Can be called after calling `-stop`. */
  39. - (void)start;
  40. /** Stops the server. */
  41. - (void)stop;
  42. /** Returns YES if the server is running, NO otherwise.
  43. *
  44. * @return YES if the server is running, NO otherwise.
  45. */
  46. - (BOOL)isRunning;
  47. @end
  48. NS_ASSUME_NONNULL_END