Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
 
 
 

712 строки
20 KiB

  1. // Copyright 2019 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. // https://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. // Code generated by gapic-generator. DO NOT EDIT.
  15. package scheduler
  16. import (
  17. emptypb "github.com/golang/protobuf/ptypes/empty"
  18. schedulerpb "google.golang.org/genproto/googleapis/cloud/scheduler/v1"
  19. field_maskpb "google.golang.org/genproto/protobuf/field_mask"
  20. )
  21. import (
  22. "context"
  23. "flag"
  24. "fmt"
  25. "io"
  26. "log"
  27. "net"
  28. "os"
  29. "strings"
  30. "testing"
  31. "github.com/golang/protobuf/proto"
  32. "github.com/golang/protobuf/ptypes"
  33. "google.golang.org/api/option"
  34. status "google.golang.org/genproto/googleapis/rpc/status"
  35. "google.golang.org/grpc"
  36. "google.golang.org/grpc/codes"
  37. "google.golang.org/grpc/metadata"
  38. gstatus "google.golang.org/grpc/status"
  39. )
  40. var _ = io.EOF
  41. var _ = ptypes.MarshalAny
  42. var _ status.Status
  43. type mockCloudSchedulerServer struct {
  44. // Embed for forward compatibility.
  45. // Tests will keep working if more methods are added
  46. // in the future.
  47. schedulerpb.CloudSchedulerServer
  48. reqs []proto.Message
  49. // If set, all calls return this error.
  50. err error
  51. // responses to return if err == nil
  52. resps []proto.Message
  53. }
  54. func (s *mockCloudSchedulerServer) ListJobs(ctx context.Context, req *schedulerpb.ListJobsRequest) (*schedulerpb.ListJobsResponse, error) {
  55. md, _ := metadata.FromIncomingContext(ctx)
  56. if xg := md["x-goog-api-client"]; len(xg) == 0 || !strings.Contains(xg[0], "gl-go/") {
  57. return nil, fmt.Errorf("x-goog-api-client = %v, expected gl-go key", xg)
  58. }
  59. s.reqs = append(s.reqs, req)
  60. if s.err != nil {
  61. return nil, s.err
  62. }
  63. return s.resps[0].(*schedulerpb.ListJobsResponse), nil
  64. }
  65. func (s *mockCloudSchedulerServer) GetJob(ctx context.Context, req *schedulerpb.GetJobRequest) (*schedulerpb.Job, error) {
  66. md, _ := metadata.FromIncomingContext(ctx)
  67. if xg := md["x-goog-api-client"]; len(xg) == 0 || !strings.Contains(xg[0], "gl-go/") {
  68. return nil, fmt.Errorf("x-goog-api-client = %v, expected gl-go key", xg)
  69. }
  70. s.reqs = append(s.reqs, req)
  71. if s.err != nil {
  72. return nil, s.err
  73. }
  74. return s.resps[0].(*schedulerpb.Job), nil
  75. }
  76. func (s *mockCloudSchedulerServer) CreateJob(ctx context.Context, req *schedulerpb.CreateJobRequest) (*schedulerpb.Job, error) {
  77. md, _ := metadata.FromIncomingContext(ctx)
  78. if xg := md["x-goog-api-client"]; len(xg) == 0 || !strings.Contains(xg[0], "gl-go/") {
  79. return nil, fmt.Errorf("x-goog-api-client = %v, expected gl-go key", xg)
  80. }
  81. s.reqs = append(s.reqs, req)
  82. if s.err != nil {
  83. return nil, s.err
  84. }
  85. return s.resps[0].(*schedulerpb.Job), nil
  86. }
  87. func (s *mockCloudSchedulerServer) UpdateJob(ctx context.Context, req *schedulerpb.UpdateJobRequest) (*schedulerpb.Job, error) {
  88. md, _ := metadata.FromIncomingContext(ctx)
  89. if xg := md["x-goog-api-client"]; len(xg) == 0 || !strings.Contains(xg[0], "gl-go/") {
  90. return nil, fmt.Errorf("x-goog-api-client = %v, expected gl-go key", xg)
  91. }
  92. s.reqs = append(s.reqs, req)
  93. if s.err != nil {
  94. return nil, s.err
  95. }
  96. return s.resps[0].(*schedulerpb.Job), nil
  97. }
  98. func (s *mockCloudSchedulerServer) DeleteJob(ctx context.Context, req *schedulerpb.DeleteJobRequest) (*emptypb.Empty, error) {
  99. md, _ := metadata.FromIncomingContext(ctx)
  100. if xg := md["x-goog-api-client"]; len(xg) == 0 || !strings.Contains(xg[0], "gl-go/") {
  101. return nil, fmt.Errorf("x-goog-api-client = %v, expected gl-go key", xg)
  102. }
  103. s.reqs = append(s.reqs, req)
  104. if s.err != nil {
  105. return nil, s.err
  106. }
  107. return s.resps[0].(*emptypb.Empty), nil
  108. }
  109. func (s *mockCloudSchedulerServer) PauseJob(ctx context.Context, req *schedulerpb.PauseJobRequest) (*schedulerpb.Job, error) {
  110. md, _ := metadata.FromIncomingContext(ctx)
  111. if xg := md["x-goog-api-client"]; len(xg) == 0 || !strings.Contains(xg[0], "gl-go/") {
  112. return nil, fmt.Errorf("x-goog-api-client = %v, expected gl-go key", xg)
  113. }
  114. s.reqs = append(s.reqs, req)
  115. if s.err != nil {
  116. return nil, s.err
  117. }
  118. return s.resps[0].(*schedulerpb.Job), nil
  119. }
  120. func (s *mockCloudSchedulerServer) ResumeJob(ctx context.Context, req *schedulerpb.ResumeJobRequest) (*schedulerpb.Job, error) {
  121. md, _ := metadata.FromIncomingContext(ctx)
  122. if xg := md["x-goog-api-client"]; len(xg) == 0 || !strings.Contains(xg[0], "gl-go/") {
  123. return nil, fmt.Errorf("x-goog-api-client = %v, expected gl-go key", xg)
  124. }
  125. s.reqs = append(s.reqs, req)
  126. if s.err != nil {
  127. return nil, s.err
  128. }
  129. return s.resps[0].(*schedulerpb.Job), nil
  130. }
  131. func (s *mockCloudSchedulerServer) RunJob(ctx context.Context, req *schedulerpb.RunJobRequest) (*schedulerpb.Job, error) {
  132. md, _ := metadata.FromIncomingContext(ctx)
  133. if xg := md["x-goog-api-client"]; len(xg) == 0 || !strings.Contains(xg[0], "gl-go/") {
  134. return nil, fmt.Errorf("x-goog-api-client = %v, expected gl-go key", xg)
  135. }
  136. s.reqs = append(s.reqs, req)
  137. if s.err != nil {
  138. return nil, s.err
  139. }
  140. return s.resps[0].(*schedulerpb.Job), nil
  141. }
  142. // clientOpt is the option tests should use to connect to the test server.
  143. // It is initialized by TestMain.
  144. var clientOpt option.ClientOption
  145. var (
  146. mockCloudScheduler mockCloudSchedulerServer
  147. )
  148. func TestMain(m *testing.M) {
  149. flag.Parse()
  150. serv := grpc.NewServer()
  151. schedulerpb.RegisterCloudSchedulerServer(serv, &mockCloudScheduler)
  152. lis, err := net.Listen("tcp", "localhost:0")
  153. if err != nil {
  154. log.Fatal(err)
  155. }
  156. go serv.Serve(lis)
  157. conn, err := grpc.Dial(lis.Addr().String(), grpc.WithInsecure())
  158. if err != nil {
  159. log.Fatal(err)
  160. }
  161. clientOpt = option.WithGRPCConn(conn)
  162. os.Exit(m.Run())
  163. }
  164. func TestCloudSchedulerListJobs(t *testing.T) {
  165. var nextPageToken string = ""
  166. var jobsElement *schedulerpb.Job = &schedulerpb.Job{}
  167. var jobs = []*schedulerpb.Job{jobsElement}
  168. var expectedResponse = &schedulerpb.ListJobsResponse{
  169. NextPageToken: nextPageToken,
  170. Jobs: jobs,
  171. }
  172. mockCloudScheduler.err = nil
  173. mockCloudScheduler.reqs = nil
  174. mockCloudScheduler.resps = append(mockCloudScheduler.resps[:0], expectedResponse)
  175. var formattedParent string = fmt.Sprintf("projects/%s/locations/%s", "[PROJECT]", "[LOCATION]")
  176. var request = &schedulerpb.ListJobsRequest{
  177. Parent: formattedParent,
  178. }
  179. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  180. if err != nil {
  181. t.Fatal(err)
  182. }
  183. resp, err := c.ListJobs(context.Background(), request).Next()
  184. if err != nil {
  185. t.Fatal(err)
  186. }
  187. if want, got := request, mockCloudScheduler.reqs[0]; !proto.Equal(want, got) {
  188. t.Errorf("wrong request %q, want %q", got, want)
  189. }
  190. want := (interface{})(expectedResponse.Jobs[0])
  191. got := (interface{})(resp)
  192. var ok bool
  193. switch want := (want).(type) {
  194. case proto.Message:
  195. ok = proto.Equal(want, got.(proto.Message))
  196. default:
  197. ok = want == got
  198. }
  199. if !ok {
  200. t.Errorf("wrong response %q, want %q)", got, want)
  201. }
  202. }
  203. func TestCloudSchedulerListJobsError(t *testing.T) {
  204. errCode := codes.PermissionDenied
  205. mockCloudScheduler.err = gstatus.Error(errCode, "test error")
  206. var formattedParent string = fmt.Sprintf("projects/%s/locations/%s", "[PROJECT]", "[LOCATION]")
  207. var request = &schedulerpb.ListJobsRequest{
  208. Parent: formattedParent,
  209. }
  210. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  211. if err != nil {
  212. t.Fatal(err)
  213. }
  214. resp, err := c.ListJobs(context.Background(), request).Next()
  215. if st, ok := gstatus.FromError(err); !ok {
  216. t.Errorf("got error %v, expected grpc error", err)
  217. } else if c := st.Code(); c != errCode {
  218. t.Errorf("got error code %q, want %q", c, errCode)
  219. }
  220. _ = resp
  221. }
  222. func TestCloudSchedulerGetJob(t *testing.T) {
  223. var name2 string = "name2-1052831874"
  224. var description string = "description-1724546052"
  225. var schedule string = "schedule-697920873"
  226. var timeZone string = "timeZone36848094"
  227. var expectedResponse = &schedulerpb.Job{
  228. Name: name2,
  229. Description: description,
  230. Schedule: schedule,
  231. TimeZone: timeZone,
  232. }
  233. mockCloudScheduler.err = nil
  234. mockCloudScheduler.reqs = nil
  235. mockCloudScheduler.resps = append(mockCloudScheduler.resps[:0], expectedResponse)
  236. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  237. var request = &schedulerpb.GetJobRequest{
  238. Name: formattedName,
  239. }
  240. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  241. if err != nil {
  242. t.Fatal(err)
  243. }
  244. resp, err := c.GetJob(context.Background(), request)
  245. if err != nil {
  246. t.Fatal(err)
  247. }
  248. if want, got := request, mockCloudScheduler.reqs[0]; !proto.Equal(want, got) {
  249. t.Errorf("wrong request %q, want %q", got, want)
  250. }
  251. if want, got := expectedResponse, resp; !proto.Equal(want, got) {
  252. t.Errorf("wrong response %q, want %q)", got, want)
  253. }
  254. }
  255. func TestCloudSchedulerGetJobError(t *testing.T) {
  256. errCode := codes.PermissionDenied
  257. mockCloudScheduler.err = gstatus.Error(errCode, "test error")
  258. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  259. var request = &schedulerpb.GetJobRequest{
  260. Name: formattedName,
  261. }
  262. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  263. if err != nil {
  264. t.Fatal(err)
  265. }
  266. resp, err := c.GetJob(context.Background(), request)
  267. if st, ok := gstatus.FromError(err); !ok {
  268. t.Errorf("got error %v, expected grpc error", err)
  269. } else if c := st.Code(); c != errCode {
  270. t.Errorf("got error code %q, want %q", c, errCode)
  271. }
  272. _ = resp
  273. }
  274. func TestCloudSchedulerCreateJob(t *testing.T) {
  275. var name string = "name3373707"
  276. var description string = "description-1724546052"
  277. var schedule string = "schedule-697920873"
  278. var timeZone string = "timeZone36848094"
  279. var expectedResponse = &schedulerpb.Job{
  280. Name: name,
  281. Description: description,
  282. Schedule: schedule,
  283. TimeZone: timeZone,
  284. }
  285. mockCloudScheduler.err = nil
  286. mockCloudScheduler.reqs = nil
  287. mockCloudScheduler.resps = append(mockCloudScheduler.resps[:0], expectedResponse)
  288. var formattedParent string = fmt.Sprintf("projects/%s/locations/%s", "[PROJECT]", "[LOCATION]")
  289. var job *schedulerpb.Job = &schedulerpb.Job{}
  290. var request = &schedulerpb.CreateJobRequest{
  291. Parent: formattedParent,
  292. Job: job,
  293. }
  294. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  295. if err != nil {
  296. t.Fatal(err)
  297. }
  298. resp, err := c.CreateJob(context.Background(), request)
  299. if err != nil {
  300. t.Fatal(err)
  301. }
  302. if want, got := request, mockCloudScheduler.reqs[0]; !proto.Equal(want, got) {
  303. t.Errorf("wrong request %q, want %q", got, want)
  304. }
  305. if want, got := expectedResponse, resp; !proto.Equal(want, got) {
  306. t.Errorf("wrong response %q, want %q)", got, want)
  307. }
  308. }
  309. func TestCloudSchedulerCreateJobError(t *testing.T) {
  310. errCode := codes.PermissionDenied
  311. mockCloudScheduler.err = gstatus.Error(errCode, "test error")
  312. var formattedParent string = fmt.Sprintf("projects/%s/locations/%s", "[PROJECT]", "[LOCATION]")
  313. var job *schedulerpb.Job = &schedulerpb.Job{}
  314. var request = &schedulerpb.CreateJobRequest{
  315. Parent: formattedParent,
  316. Job: job,
  317. }
  318. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  319. if err != nil {
  320. t.Fatal(err)
  321. }
  322. resp, err := c.CreateJob(context.Background(), request)
  323. if st, ok := gstatus.FromError(err); !ok {
  324. t.Errorf("got error %v, expected grpc error", err)
  325. } else if c := st.Code(); c != errCode {
  326. t.Errorf("got error code %q, want %q", c, errCode)
  327. }
  328. _ = resp
  329. }
  330. func TestCloudSchedulerUpdateJob(t *testing.T) {
  331. var name string = "name3373707"
  332. var description string = "description-1724546052"
  333. var schedule string = "schedule-697920873"
  334. var timeZone string = "timeZone36848094"
  335. var expectedResponse = &schedulerpb.Job{
  336. Name: name,
  337. Description: description,
  338. Schedule: schedule,
  339. TimeZone: timeZone,
  340. }
  341. mockCloudScheduler.err = nil
  342. mockCloudScheduler.reqs = nil
  343. mockCloudScheduler.resps = append(mockCloudScheduler.resps[:0], expectedResponse)
  344. var job *schedulerpb.Job = &schedulerpb.Job{}
  345. var updateMask *field_maskpb.FieldMask = &field_maskpb.FieldMask{}
  346. var request = &schedulerpb.UpdateJobRequest{
  347. Job: job,
  348. UpdateMask: updateMask,
  349. }
  350. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  351. if err != nil {
  352. t.Fatal(err)
  353. }
  354. resp, err := c.UpdateJob(context.Background(), request)
  355. if err != nil {
  356. t.Fatal(err)
  357. }
  358. if want, got := request, mockCloudScheduler.reqs[0]; !proto.Equal(want, got) {
  359. t.Errorf("wrong request %q, want %q", got, want)
  360. }
  361. if want, got := expectedResponse, resp; !proto.Equal(want, got) {
  362. t.Errorf("wrong response %q, want %q)", got, want)
  363. }
  364. }
  365. func TestCloudSchedulerUpdateJobError(t *testing.T) {
  366. errCode := codes.PermissionDenied
  367. mockCloudScheduler.err = gstatus.Error(errCode, "test error")
  368. var job *schedulerpb.Job = &schedulerpb.Job{}
  369. var updateMask *field_maskpb.FieldMask = &field_maskpb.FieldMask{}
  370. var request = &schedulerpb.UpdateJobRequest{
  371. Job: job,
  372. UpdateMask: updateMask,
  373. }
  374. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  375. if err != nil {
  376. t.Fatal(err)
  377. }
  378. resp, err := c.UpdateJob(context.Background(), request)
  379. if st, ok := gstatus.FromError(err); !ok {
  380. t.Errorf("got error %v, expected grpc error", err)
  381. } else if c := st.Code(); c != errCode {
  382. t.Errorf("got error code %q, want %q", c, errCode)
  383. }
  384. _ = resp
  385. }
  386. func TestCloudSchedulerDeleteJob(t *testing.T) {
  387. var expectedResponse *emptypb.Empty = &emptypb.Empty{}
  388. mockCloudScheduler.err = nil
  389. mockCloudScheduler.reqs = nil
  390. mockCloudScheduler.resps = append(mockCloudScheduler.resps[:0], expectedResponse)
  391. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  392. var request = &schedulerpb.DeleteJobRequest{
  393. Name: formattedName,
  394. }
  395. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  396. if err != nil {
  397. t.Fatal(err)
  398. }
  399. err = c.DeleteJob(context.Background(), request)
  400. if err != nil {
  401. t.Fatal(err)
  402. }
  403. if want, got := request, mockCloudScheduler.reqs[0]; !proto.Equal(want, got) {
  404. t.Errorf("wrong request %q, want %q", got, want)
  405. }
  406. }
  407. func TestCloudSchedulerDeleteJobError(t *testing.T) {
  408. errCode := codes.PermissionDenied
  409. mockCloudScheduler.err = gstatus.Error(errCode, "test error")
  410. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  411. var request = &schedulerpb.DeleteJobRequest{
  412. Name: formattedName,
  413. }
  414. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  415. if err != nil {
  416. t.Fatal(err)
  417. }
  418. err = c.DeleteJob(context.Background(), request)
  419. if st, ok := gstatus.FromError(err); !ok {
  420. t.Errorf("got error %v, expected grpc error", err)
  421. } else if c := st.Code(); c != errCode {
  422. t.Errorf("got error code %q, want %q", c, errCode)
  423. }
  424. }
  425. func TestCloudSchedulerPauseJob(t *testing.T) {
  426. var name2 string = "name2-1052831874"
  427. var description string = "description-1724546052"
  428. var schedule string = "schedule-697920873"
  429. var timeZone string = "timeZone36848094"
  430. var expectedResponse = &schedulerpb.Job{
  431. Name: name2,
  432. Description: description,
  433. Schedule: schedule,
  434. TimeZone: timeZone,
  435. }
  436. mockCloudScheduler.err = nil
  437. mockCloudScheduler.reqs = nil
  438. mockCloudScheduler.resps = append(mockCloudScheduler.resps[:0], expectedResponse)
  439. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  440. var request = &schedulerpb.PauseJobRequest{
  441. Name: formattedName,
  442. }
  443. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  444. if err != nil {
  445. t.Fatal(err)
  446. }
  447. resp, err := c.PauseJob(context.Background(), request)
  448. if err != nil {
  449. t.Fatal(err)
  450. }
  451. if want, got := request, mockCloudScheduler.reqs[0]; !proto.Equal(want, got) {
  452. t.Errorf("wrong request %q, want %q", got, want)
  453. }
  454. if want, got := expectedResponse, resp; !proto.Equal(want, got) {
  455. t.Errorf("wrong response %q, want %q)", got, want)
  456. }
  457. }
  458. func TestCloudSchedulerPauseJobError(t *testing.T) {
  459. errCode := codes.PermissionDenied
  460. mockCloudScheduler.err = gstatus.Error(errCode, "test error")
  461. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  462. var request = &schedulerpb.PauseJobRequest{
  463. Name: formattedName,
  464. }
  465. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  466. if err != nil {
  467. t.Fatal(err)
  468. }
  469. resp, err := c.PauseJob(context.Background(), request)
  470. if st, ok := gstatus.FromError(err); !ok {
  471. t.Errorf("got error %v, expected grpc error", err)
  472. } else if c := st.Code(); c != errCode {
  473. t.Errorf("got error code %q, want %q", c, errCode)
  474. }
  475. _ = resp
  476. }
  477. func TestCloudSchedulerResumeJob(t *testing.T) {
  478. var name2 string = "name2-1052831874"
  479. var description string = "description-1724546052"
  480. var schedule string = "schedule-697920873"
  481. var timeZone string = "timeZone36848094"
  482. var expectedResponse = &schedulerpb.Job{
  483. Name: name2,
  484. Description: description,
  485. Schedule: schedule,
  486. TimeZone: timeZone,
  487. }
  488. mockCloudScheduler.err = nil
  489. mockCloudScheduler.reqs = nil
  490. mockCloudScheduler.resps = append(mockCloudScheduler.resps[:0], expectedResponse)
  491. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  492. var request = &schedulerpb.ResumeJobRequest{
  493. Name: formattedName,
  494. }
  495. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  496. if err != nil {
  497. t.Fatal(err)
  498. }
  499. resp, err := c.ResumeJob(context.Background(), request)
  500. if err != nil {
  501. t.Fatal(err)
  502. }
  503. if want, got := request, mockCloudScheduler.reqs[0]; !proto.Equal(want, got) {
  504. t.Errorf("wrong request %q, want %q", got, want)
  505. }
  506. if want, got := expectedResponse, resp; !proto.Equal(want, got) {
  507. t.Errorf("wrong response %q, want %q)", got, want)
  508. }
  509. }
  510. func TestCloudSchedulerResumeJobError(t *testing.T) {
  511. errCode := codes.PermissionDenied
  512. mockCloudScheduler.err = gstatus.Error(errCode, "test error")
  513. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  514. var request = &schedulerpb.ResumeJobRequest{
  515. Name: formattedName,
  516. }
  517. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  518. if err != nil {
  519. t.Fatal(err)
  520. }
  521. resp, err := c.ResumeJob(context.Background(), request)
  522. if st, ok := gstatus.FromError(err); !ok {
  523. t.Errorf("got error %v, expected grpc error", err)
  524. } else if c := st.Code(); c != errCode {
  525. t.Errorf("got error code %q, want %q", c, errCode)
  526. }
  527. _ = resp
  528. }
  529. func TestCloudSchedulerRunJob(t *testing.T) {
  530. var name2 string = "name2-1052831874"
  531. var description string = "description-1724546052"
  532. var schedule string = "schedule-697920873"
  533. var timeZone string = "timeZone36848094"
  534. var expectedResponse = &schedulerpb.Job{
  535. Name: name2,
  536. Description: description,
  537. Schedule: schedule,
  538. TimeZone: timeZone,
  539. }
  540. mockCloudScheduler.err = nil
  541. mockCloudScheduler.reqs = nil
  542. mockCloudScheduler.resps = append(mockCloudScheduler.resps[:0], expectedResponse)
  543. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  544. var request = &schedulerpb.RunJobRequest{
  545. Name: formattedName,
  546. }
  547. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  548. if err != nil {
  549. t.Fatal(err)
  550. }
  551. resp, err := c.RunJob(context.Background(), request)
  552. if err != nil {
  553. t.Fatal(err)
  554. }
  555. if want, got := request, mockCloudScheduler.reqs[0]; !proto.Equal(want, got) {
  556. t.Errorf("wrong request %q, want %q", got, want)
  557. }
  558. if want, got := expectedResponse, resp; !proto.Equal(want, got) {
  559. t.Errorf("wrong response %q, want %q)", got, want)
  560. }
  561. }
  562. func TestCloudSchedulerRunJobError(t *testing.T) {
  563. errCode := codes.PermissionDenied
  564. mockCloudScheduler.err = gstatus.Error(errCode, "test error")
  565. var formattedName string = fmt.Sprintf("projects/%s/locations/%s/jobs/%s", "[PROJECT]", "[LOCATION]", "[JOB]")
  566. var request = &schedulerpb.RunJobRequest{
  567. Name: formattedName,
  568. }
  569. c, err := NewCloudSchedulerClient(context.Background(), clientOpt)
  570. if err != nil {
  571. t.Fatal(err)
  572. }
  573. resp, err := c.RunJob(context.Background(), request)
  574. if st, ok := gstatus.FromError(err); !ok {
  575. t.Errorf("got error %v, expected grpc error", err)
  576. } else if c := st.Code(); c != errCode {
  577. t.Errorf("got error code %q, want %q", c, errCode)
  578. }
  579. _ = resp
  580. }