Package.swift 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741
  1. // swift-tools-version:5.7
  2. /*
  3. * Copyright 2017, gRPC Authors All rights reserved.
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. import PackageDescription
  18. // swiftformat puts the next import before the tools version.
  19. // swiftformat:disable:next sortImports
  20. import class Foundation.ProcessInfo
  21. let grpcPackageName = "grpc-swift"
  22. let grpcProductName = "GRPC"
  23. let cgrpcZlibProductName = "CGRPCZlib"
  24. let grpcTargetName = grpcProductName
  25. let cgrpcZlibTargetName = cgrpcZlibProductName
  26. let includeNIOSSL = ProcessInfo.processInfo.environment["GRPC_NO_NIO_SSL"] == nil
  27. // MARK: - Package Dependencies
  28. let packageDependencies: [Package.Dependency] = [
  29. .package(
  30. url: "https://github.com/apple/swift-nio.git",
  31. from: "2.58.0"
  32. ),
  33. .package(
  34. url: "https://github.com/apple/swift-nio-http2.git",
  35. from: "1.24.1"
  36. ),
  37. .package(
  38. url: "https://github.com/apple/swift-nio-transport-services.git",
  39. from: "1.15.0"
  40. ),
  41. .package(
  42. url: "https://github.com/apple/swift-nio-extras.git",
  43. from: "1.4.0"
  44. ),
  45. .package(
  46. url: "https://github.com/apple/swift-collections.git",
  47. from: "1.0.5"
  48. ),
  49. .package(
  50. url: "https://github.com/apple/swift-atomics.git",
  51. from: "1.2.0"
  52. ),
  53. .package(
  54. url: "https://github.com/apple/swift-protobuf.git",
  55. from: "1.20.2"
  56. ),
  57. .package(
  58. url: "https://github.com/apple/swift-log.git",
  59. from: "1.4.4"
  60. ),
  61. .package(
  62. url: "https://github.com/apple/swift-argument-parser.git",
  63. // Version is higher than in other Package@swift manifests: 1.1.0 raised the minimum Swift
  64. // version and indluded async support.
  65. from: "1.1.1"
  66. ),
  67. .package(
  68. url: "https://github.com/apple/swift-docc-plugin",
  69. from: "1.0.0"
  70. ),
  71. .package(
  72. url: "https://github.com/apple/swift-distributed-tracing.git",
  73. from: "1.0.0"
  74. ),
  75. ].appending(
  76. .package(
  77. url: "https://github.com/apple/swift-nio-ssl.git",
  78. from: "2.23.0"
  79. ),
  80. if: includeNIOSSL
  81. )
  82. // MARK: - Target Dependencies
  83. extension Target.Dependency {
  84. // Target dependencies; external
  85. static let grpc: Self = .target(name: grpcTargetName)
  86. static let cgrpcZlib: Self = .target(name: cgrpcZlibTargetName)
  87. static let protocGenGRPCSwift: Self = .target(name: "protoc-gen-grpc-swift")
  88. static let reflectionService: Self = .target(name: "GRPCReflectionService")
  89. static let grpcCodeGen: Self = .target(name: "GRPCCodeGen")
  90. static let grpcProtobuf: Self = .target(name: "GRPCProtobuf")
  91. static let grpcProtobufCodeGen: Self = .target(name: "GRPCProtobufCodeGen")
  92. // Target dependencies; internal
  93. static let grpcSampleData: Self = .target(name: "GRPCSampleData")
  94. static let echoModel: Self = .target(name: "EchoModel")
  95. static let echoImplementation: Self = .target(name: "EchoImplementation")
  96. static let helloWorldModel: Self = .target(name: "HelloWorldModel")
  97. static let routeGuideModel: Self = .target(name: "RouteGuideModel")
  98. static let interopTestModels: Self = .target(name: "GRPCInteroperabilityTestModels")
  99. static let interopTestImplementation: Self =
  100. .target(name: "GRPCInteroperabilityTestsImplementation")
  101. // Product dependencies
  102. static let argumentParser: Self = .product(
  103. name: "ArgumentParser",
  104. package: "swift-argument-parser"
  105. )
  106. static let nio: Self = .product(name: "NIO", package: "swift-nio")
  107. static let nioConcurrencyHelpers: Self = .product(
  108. name: "NIOConcurrencyHelpers",
  109. package: "swift-nio"
  110. )
  111. static let nioCore: Self = .product(name: "NIOCore", package: "swift-nio")
  112. static let nioEmbedded: Self = .product(name: "NIOEmbedded", package: "swift-nio")
  113. static let nioExtras: Self = .product(name: "NIOExtras", package: "swift-nio-extras")
  114. static let nioFoundationCompat: Self = .product(name: "NIOFoundationCompat", package: "swift-nio")
  115. static let nioHTTP1: Self = .product(name: "NIOHTTP1", package: "swift-nio")
  116. static let nioHTTP2: Self = .product(name: "NIOHTTP2", package: "swift-nio-http2")
  117. static let nioPosix: Self = .product(name: "NIOPosix", package: "swift-nio")
  118. static let nioSSL: Self = .product(name: "NIOSSL", package: "swift-nio-ssl")
  119. static let nioTLS: Self = .product(name: "NIOTLS", package: "swift-nio")
  120. static let nioTransportServices: Self = .product(
  121. name: "NIOTransportServices",
  122. package: "swift-nio-transport-services"
  123. )
  124. static let nioTestUtils: Self = .product(name: "NIOTestUtils", package: "swift-nio")
  125. static let logging: Self = .product(name: "Logging", package: "swift-log")
  126. static let protobuf: Self = .product(name: "SwiftProtobuf", package: "swift-protobuf")
  127. static let protobufPluginLibrary: Self = .product(
  128. name: "SwiftProtobufPluginLibrary",
  129. package: "swift-protobuf"
  130. )
  131. static let dequeModule: Self = .product(name: "DequeModule", package: "swift-collections")
  132. static let atomics: Self = .product(name: "Atomics", package: "swift-atomics")
  133. static let tracing: Self = .product(name: "Tracing", package: "swift-distributed-tracing")
  134. static let grpcCore: Self = .target(name: "GRPCCore")
  135. static let grpcInProcessTransport: Self = .target(name: "GRPCInProcessTransport")
  136. static let grpcInterceptors: Self = .target(name: "GRPCInterceptors")
  137. static let grpcHTTP2Core: Self = .target(name: "GRPCHTTP2Core")
  138. static let grpcHTTP2TransportNIOPosix: Self = .target(name: "GRPCHTTP2TransportNIOPosix")
  139. static let grpcHTTP2TransportNIOTransportServices: Self = .target(name: "GRPCHTTP2TransportNIOTransportServices")
  140. }
  141. // MARK: - Targets
  142. extension Target {
  143. static let grpc: Target = .target(
  144. name: grpcTargetName,
  145. dependencies: [
  146. .cgrpcZlib,
  147. .nio,
  148. .nioCore,
  149. .nioPosix,
  150. .nioEmbedded,
  151. .nioFoundationCompat,
  152. .nioTLS,
  153. .nioTransportServices,
  154. .nioHTTP1,
  155. .nioHTTP2,
  156. .nioExtras,
  157. .logging,
  158. .protobuf,
  159. .dequeModule,
  160. ].appending(
  161. .nioSSL, if: includeNIOSSL
  162. ),
  163. path: "Sources/GRPC"
  164. )
  165. static let grpcCore: Target = .target(
  166. name: "GRPCCore",
  167. dependencies: [
  168. .dequeModule,
  169. .atomics
  170. ],
  171. path: "Sources/GRPCCore"
  172. )
  173. static let grpcInProcessTransport: Target = .target(
  174. name: "GRPCInProcessTransport",
  175. dependencies: [
  176. .grpcCore
  177. ]
  178. )
  179. static let grpcInterceptors: Target = .target(
  180. name: "GRPCInterceptors",
  181. dependencies: [
  182. .grpcCore,
  183. .tracing
  184. ]
  185. )
  186. static let grpcHTTP2Core: Target = .target(
  187. name: "GRPCHTTP2Core",
  188. dependencies: [
  189. .grpcCore,
  190. .nioCore,
  191. .nioHTTP2,
  192. .cgrpcZlib,
  193. .dequeModule
  194. ]
  195. )
  196. static let grpcHTTP2TransportNIOPosix: Target = .target(
  197. name: "GRPCHTTP2TransportNIOPosix",
  198. dependencies: [
  199. .grpcHTTP2Core
  200. ]
  201. )
  202. static let grpcHTTP2TransportNIOTransportServices: Target = .target(
  203. name: "GRPCHTTP2TransportNIOTransportServices",
  204. dependencies: [
  205. .grpcHTTP2Core
  206. ]
  207. )
  208. static let cgrpcZlib: Target = .target(
  209. name: cgrpcZlibTargetName,
  210. path: "Sources/CGRPCZlib",
  211. linkerSettings: [
  212. .linkedLibrary("z"),
  213. ]
  214. )
  215. static let protocGenGRPCSwift: Target = .executableTarget(
  216. name: "protoc-gen-grpc-swift",
  217. dependencies: [
  218. .protobuf,
  219. .protobufPluginLibrary,
  220. .grpcCodeGen,
  221. .grpcProtobufCodeGen
  222. ],
  223. exclude: [
  224. "README.md",
  225. ]
  226. )
  227. static let grpcSwiftPlugin: Target = .plugin(
  228. name: "GRPCSwiftPlugin",
  229. capability: .buildTool(),
  230. dependencies: [
  231. .protocGenGRPCSwift,
  232. ]
  233. )
  234. static let grpcTests: Target = .testTarget(
  235. name: "GRPCTests",
  236. dependencies: [
  237. .grpc,
  238. .echoModel,
  239. .echoImplementation,
  240. .helloWorldModel,
  241. .interopTestModels,
  242. .interopTestImplementation,
  243. .grpcSampleData,
  244. .nioCore,
  245. .nioConcurrencyHelpers,
  246. .nioPosix,
  247. .nioTLS,
  248. .nioHTTP1,
  249. .nioHTTP2,
  250. .nioEmbedded,
  251. .nioTransportServices,
  252. .logging,
  253. .reflectionService
  254. ].appending(
  255. .nioSSL, if: includeNIOSSL
  256. ),
  257. exclude: [
  258. "Codegen/Normalization/normalization.proto",
  259. "Codegen/Serialization/echo.grpc.reflection",
  260. ]
  261. )
  262. static let grpcCoreTests: Target = .testTarget(
  263. name: "GRPCCoreTests",
  264. dependencies: [
  265. .grpcCore,
  266. .grpcInProcessTransport,
  267. .dequeModule,
  268. .atomics
  269. ]
  270. )
  271. static let grpcInProcessTransportTests: Target = .testTarget(
  272. name: "GRPCInProcessTransportTests",
  273. dependencies: [
  274. .grpcCore,
  275. .grpcInProcessTransport
  276. ]
  277. )
  278. static let grpcInterceptorsTests: Target = .testTarget(
  279. name: "GRPCInterceptorsTests",
  280. dependencies: [
  281. .grpcCore,
  282. .tracing,
  283. .nioCore,
  284. .grpcInterceptors
  285. ]
  286. )
  287. static let grpcHTTP2CoreTests: Target = .testTarget(
  288. name: "GRPCHTTP2CoreTests",
  289. dependencies: [
  290. .grpcHTTP2Core,
  291. .nioCore,
  292. .nioHTTP2,
  293. .nioEmbedded,
  294. .nioTestUtils,
  295. ]
  296. )
  297. static let grpcHTTP2TransportNIOPosixTests: Target = .testTarget(
  298. name: "GRPCHTTP2TransportNIOPosixTests",
  299. dependencies: [
  300. .grpcHTTP2TransportNIOPosix
  301. ]
  302. )
  303. static let grpcHTTP2TransportNIOTransportServicesTests: Target = .testTarget(
  304. name: "GRPCHTTP2TransportNIOTransportServicesTests",
  305. dependencies: [
  306. .grpcHTTP2TransportNIOTransportServices
  307. ]
  308. )
  309. static let grpcCodeGenTests: Target = .testTarget(
  310. name: "GRPCCodeGenTests",
  311. dependencies: [
  312. .grpcCodeGen
  313. ]
  314. )
  315. static let grpcProtobufTests: Target = .testTarget(
  316. name: "GRPCProtobufTests",
  317. dependencies: [
  318. .grpcProtobuf,
  319. .grpcCore,
  320. .protobuf
  321. ]
  322. )
  323. static let grpcProtobufCodeGenTests: Target = .testTarget(
  324. name: "GRPCProtobufCodeGenTests",
  325. dependencies: [
  326. .grpcCodeGen,
  327. .grpcProtobufCodeGen,
  328. .protobuf,
  329. .protobufPluginLibrary
  330. ]
  331. )
  332. static let interopTestModels: Target = .target(
  333. name: "GRPCInteroperabilityTestModels",
  334. dependencies: [
  335. .grpc,
  336. .nio,
  337. .protobuf,
  338. ],
  339. exclude: [
  340. "README.md",
  341. "generate.sh",
  342. "src/proto/grpc/testing/empty.proto",
  343. "src/proto/grpc/testing/empty_service.proto",
  344. "src/proto/grpc/testing/messages.proto",
  345. "src/proto/grpc/testing/test.proto",
  346. "unimplemented_call.patch",
  347. ]
  348. )
  349. static let interopTestImplementation: Target = .target(
  350. name: "GRPCInteroperabilityTestsImplementation",
  351. dependencies: [
  352. .grpc,
  353. .interopTestModels,
  354. .nioCore,
  355. .nioPosix,
  356. .nioHTTP1,
  357. .logging,
  358. ].appending(
  359. .nioSSL, if: includeNIOSSL
  360. )
  361. )
  362. static let interopTests: Target = .executableTarget(
  363. name: "GRPCInteroperabilityTests",
  364. dependencies: [
  365. .grpc,
  366. .interopTestImplementation,
  367. .nioCore,
  368. .nioPosix,
  369. .logging,
  370. .argumentParser,
  371. ]
  372. )
  373. static let backoffInteropTest: Target = .executableTarget(
  374. name: "GRPCConnectionBackoffInteropTest",
  375. dependencies: [
  376. .grpc,
  377. .interopTestModels,
  378. .nioCore,
  379. .nioPosix,
  380. .logging,
  381. .argumentParser,
  382. ],
  383. exclude: [
  384. "README.md",
  385. ]
  386. )
  387. static let perfTests: Target = .executableTarget(
  388. name: "GRPCPerformanceTests",
  389. dependencies: [
  390. .grpc,
  391. .grpcSampleData,
  392. .nioCore,
  393. .nioEmbedded,
  394. .nioPosix,
  395. .nioHTTP2,
  396. .argumentParser,
  397. ]
  398. )
  399. static let grpcSampleData: Target = .target(
  400. name: "GRPCSampleData",
  401. dependencies: includeNIOSSL ? [.nioSSL] : [],
  402. exclude: [
  403. "bundle.p12",
  404. ]
  405. )
  406. static let echoModel: Target = .target(
  407. name: "EchoModel",
  408. dependencies: [
  409. .grpc,
  410. .nio,
  411. .protobuf,
  412. ],
  413. path: "Sources/Examples/Echo/Model",
  414. exclude: [
  415. "echo.proto",
  416. ]
  417. )
  418. static let echoImplementation: Target = .target(
  419. name: "EchoImplementation",
  420. dependencies: [
  421. .echoModel,
  422. .grpc,
  423. .nioCore,
  424. .nioHTTP2,
  425. .protobuf,
  426. ],
  427. path: "Sources/Examples/Echo/Implementation"
  428. )
  429. static let echo: Target = .executableTarget(
  430. name: "Echo",
  431. dependencies: [
  432. .grpc,
  433. .echoModel,
  434. .echoImplementation,
  435. .grpcSampleData,
  436. .nioCore,
  437. .nioPosix,
  438. .logging,
  439. .argumentParser,
  440. ].appending(
  441. .nioSSL, if: includeNIOSSL
  442. ),
  443. path: "Sources/Examples/Echo/Runtime"
  444. )
  445. static let helloWorldModel: Target = .target(
  446. name: "HelloWorldModel",
  447. dependencies: [
  448. .grpc,
  449. .nio,
  450. .protobuf,
  451. ],
  452. path: "Sources/Examples/HelloWorld/Model",
  453. exclude: [
  454. "helloworld.proto",
  455. ]
  456. )
  457. static let helloWorldClient: Target = .executableTarget(
  458. name: "HelloWorldClient",
  459. dependencies: [
  460. .grpc,
  461. .helloWorldModel,
  462. .nioCore,
  463. .nioPosix,
  464. .argumentParser,
  465. ],
  466. path: "Sources/Examples/HelloWorld/Client"
  467. )
  468. static let helloWorldServer: Target = .executableTarget(
  469. name: "HelloWorldServer",
  470. dependencies: [
  471. .grpc,
  472. .helloWorldModel,
  473. .nioCore,
  474. .nioPosix,
  475. .argumentParser,
  476. ],
  477. path: "Sources/Examples/HelloWorld/Server"
  478. )
  479. static let routeGuideModel: Target = .target(
  480. name: "RouteGuideModel",
  481. dependencies: [
  482. .grpc,
  483. .nio,
  484. .protobuf,
  485. ],
  486. path: "Sources/Examples/RouteGuide/Model",
  487. exclude: [
  488. "route_guide.proto",
  489. ]
  490. )
  491. static let routeGuideClient: Target = .executableTarget(
  492. name: "RouteGuideClient",
  493. dependencies: [
  494. .grpc,
  495. .routeGuideModel,
  496. .nioCore,
  497. .nioPosix,
  498. .argumentParser,
  499. ],
  500. path: "Sources/Examples/RouteGuide/Client"
  501. )
  502. static let routeGuideServer: Target = .executableTarget(
  503. name: "RouteGuideServer",
  504. dependencies: [
  505. .grpc,
  506. .routeGuideModel,
  507. .nioCore,
  508. .nioConcurrencyHelpers,
  509. .nioPosix,
  510. .argumentParser,
  511. ],
  512. path: "Sources/Examples/RouteGuide/Server"
  513. )
  514. static let packetCapture: Target = .executableTarget(
  515. name: "PacketCapture",
  516. dependencies: [
  517. .grpc,
  518. .echoModel,
  519. .nioCore,
  520. .nioPosix,
  521. .nioExtras,
  522. .argumentParser,
  523. ],
  524. path: "Sources/Examples/PacketCapture",
  525. exclude: [
  526. "README.md",
  527. ]
  528. )
  529. static let reflectionService: Target = .target(
  530. name: "GRPCReflectionService",
  531. dependencies: [
  532. .grpc,
  533. .nio,
  534. .protobuf,
  535. ],
  536. path: "Sources/GRPCReflectionService",
  537. exclude: [
  538. "v1/reflection-v1.proto",
  539. "v1Alpha/reflection-v1alpha.proto"
  540. ]
  541. )
  542. static let reflectionServer: Target = .executableTarget(
  543. name: "ReflectionServer",
  544. dependencies: [
  545. .grpc,
  546. .reflectionService,
  547. .helloWorldModel,
  548. .nioCore,
  549. .nioPosix,
  550. .argumentParser,
  551. .echoModel,
  552. .echoImplementation
  553. ],
  554. path: "Sources/Examples/ReflectionService",
  555. resources: [
  556. .copy("Generated")
  557. ]
  558. )
  559. static let grpcCodeGen: Target = .target(
  560. name: "GRPCCodeGen",
  561. path: "Sources/GRPCCodeGen"
  562. )
  563. static let grpcProtobuf: Target = .target(
  564. name: "GRPCProtobuf",
  565. dependencies: [
  566. .grpcCore,
  567. .protobuf,
  568. ],
  569. path: "Sources/GRPCProtobuf"
  570. )
  571. static let grpcProtobufCodeGen: Target = .target(
  572. name: "GRPCProtobufCodeGen",
  573. dependencies: [
  574. .protobuf,
  575. .protobufPluginLibrary,
  576. .grpcCodeGen
  577. ],
  578. path: "Sources/GRPCProtobufCodeGen"
  579. )
  580. }
  581. // MARK: - Products
  582. extension Product {
  583. static let grpc: Product = .library(
  584. name: grpcProductName,
  585. targets: [grpcTargetName]
  586. )
  587. static let grpcCore: Product = .library(
  588. name: "_GRPCCore",
  589. targets: ["GRPCCore"]
  590. )
  591. static let cgrpcZlib: Product = .library(
  592. name: cgrpcZlibProductName,
  593. targets: [cgrpcZlibTargetName]
  594. )
  595. static let grpcReflectionService: Product = .library(
  596. name: "GRPCReflectionService",
  597. targets: ["GRPCReflectionService"]
  598. )
  599. static let protocGenGRPCSwift: Product = .executable(
  600. name: "protoc-gen-grpc-swift",
  601. targets: ["protoc-gen-grpc-swift"]
  602. )
  603. static let grpcSwiftPlugin: Product = .plugin(
  604. name: "GRPCSwiftPlugin",
  605. targets: ["GRPCSwiftPlugin"]
  606. )
  607. }
  608. // MARK: - Package
  609. let package = Package(
  610. name: grpcPackageName,
  611. products: [
  612. .grpc,
  613. .grpcCore,
  614. .cgrpcZlib,
  615. .grpcReflectionService,
  616. .protocGenGRPCSwift,
  617. .grpcSwiftPlugin,
  618. ],
  619. dependencies: packageDependencies,
  620. targets: [
  621. // Products
  622. .grpc,
  623. .cgrpcZlib,
  624. .protocGenGRPCSwift,
  625. .grpcSwiftPlugin,
  626. .reflectionService,
  627. // Tests etc.
  628. .grpcTests,
  629. .interopTestModels,
  630. .interopTestImplementation,
  631. .interopTests,
  632. .backoffInteropTest,
  633. .perfTests,
  634. .grpcSampleData,
  635. // Examples
  636. .echoModel,
  637. .echoImplementation,
  638. .echo,
  639. .helloWorldModel,
  640. .helloWorldClient,
  641. .helloWorldServer,
  642. .routeGuideModel,
  643. .routeGuideClient,
  644. .routeGuideServer,
  645. .packetCapture,
  646. .reflectionServer,
  647. // v2
  648. .grpcCore,
  649. .grpcInProcessTransport,
  650. .grpcCodeGen,
  651. .grpcInterceptors,
  652. .grpcHTTP2Core,
  653. .grpcHTTP2TransportNIOPosix,
  654. .grpcHTTP2TransportNIOTransportServices,
  655. .grpcProtobuf,
  656. .grpcProtobufCodeGen,
  657. // v2 tests
  658. .grpcCoreTests,
  659. .grpcInProcessTransportTests,
  660. .grpcCodeGenTests,
  661. .grpcInterceptorsTests,
  662. .grpcHTTP2CoreTests,
  663. .grpcHTTP2TransportNIOPosixTests,
  664. .grpcHTTP2TransportNIOTransportServicesTests,
  665. .grpcProtobufTests,
  666. .grpcProtobufCodeGenTests
  667. ]
  668. )
  669. extension Array {
  670. func appending(_ element: Element, if condition: Bool) -> [Element] {
  671. if condition {
  672. return self + [element]
  673. } else {
  674. return self
  675. }
  676. }
  677. }