]> gitweb.hhaalo.de Git - sane-kds-s2000w-net.git/commitdiff
add tset for scan complete feeder
authorBastian Dehn <hhaalo@arcor.de>
Fri, 27 Dec 2024 14:51:14 +0000 (15:51 +0100)
committerBastian Dehn <hhaalo@arcor.de>
Fri, 27 Dec 2024 15:01:54 +0000 (16:01 +0100)
tests/kds_s2000w_net_tests.c
tests/kds_s2000w_net_tests.h
tests/kds_s2000w_net_tests_run.c

index c0e41f07a289a6f4c39a2812c65ecea6814e0800..20e7a87dc47816e12acca3e678f420fea5f3e91e 100644 (file)
@@ -458,6 +458,40 @@ void sane_kds_s2000w_net_cancel()
        h = NULL;
 }
 
+void sane_kds_s2000w_net_cancel_completed_scan_feeder()
+{
+       response* resp_status = kds_s2000w_client_response_init();
+       resp_status->data = realloc(resp_status->data, 210);
+       const char* status = "{ \
+               \"Status\": { \
+                       \"NumImagesScanned\": 2, \
+                       \"NumImagesStored\": 0, \
+                       \"State\": \"Done Scanning\", \
+                       \"ErrorNum\": 0, \
+                       \"LastError\": \"Status: 200 Success\", \
+                       \"PaperDetected\": \"0\", \
+                       \"PercentAvailable\": 99 \
+               }}\0";
+       memcpy(resp_status->data, status, 210);
+       resp_status->code = 200;
+       resp_status->size = 210;
+       will_return(mock_response, resp_status);
+       will_return(__wrap_kds_s2000w_client_status_session, 0);
+       expect_function_call(__wrap_kds_s2000w_client_status_session);
+
+       handler* h = init_handler();
+
+       _sane_kds_s2000w_net_cancel(h);
+
+       assert_int_equal(h->read_info->cancel, 0);
+       assert_int_equal(h->current_scan_status->complete_scanned, 0);
+
+       kds_s2000w_client_response_free(resp_status);
+       resp_status = NULL;
+       free_handler(h);
+       h = NULL;
+}
+
 void sane_kds_s2000w_net_open()
 {
        response* resp = kds_s2000w_client_response_init();
index 34c1bf89ee06f4ae0d968d3572b3778081b75c2e..e1e94e94b41472657b39e3e7d5428abe66c6f55f 100644 (file)
@@ -19,6 +19,7 @@ void sane_kds_s2000w_net_start_two_pages_per_feeder(void** state);
 void sane_kds_s2000w_net_start_slow_two_pages_per_feeder(void** state);
 void sane_kds_s2000w_net_get_parameter_cancel();
 void sane_kds_s2000w_net_cancel();
+void sane_kds_s2000w_net_cancel_completed_scan_feeder();
 void sane_kds_s2000w_net_open();
 void sane_kds_s2000w_net_open_busy_device();
 void sane_kds_s2000w_net_open_invalid();
index 1b2203eecda16c64b965d6ff2405914bad720e8c..9883245146301f257d232d7262a89e38e33c9079 100644 (file)
@@ -70,6 +70,7 @@ int main()
                cmocka_unit_test(kds_s2000w_net_get_select_fd),
                cmocka_unit_test(sane_kds_s2000w_net_start_cancel),
                cmocka_unit_test(sane_kds_s2000w_net_cancel),
+               cmocka_unit_test(sane_kds_s2000w_net_cancel_completed_scan_feeder),
                cmocka_unit_test(sane_kds_s2000w_net_open),
                cmocka_unit_test(sane_kds_s2000w_net_open_busy_device),
                cmocka_unit_test(sane_kds_s2000w_net_open_invalid),