summaryrefslogtreecommitdiff
path: root/src/test/test_pt.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2013-07-29 11:37:39 -0400
committerNick Mathewson <nickm@torproject.org>2013-07-31 13:34:16 -0400
commit22a074caa71723b35c3a59620f8a2ebdbf290388 (patch)
tree1da68b80fa4b22688b86edcf21494e6e223a19e4 /src/test/test_pt.c
parent99bb6d2937a76caf7d6085fb063d89c1c8b3d9b6 (diff)
downloadtor-22a074caa71723b35c3a59620f8a2ebdbf290388.tar.gz
tor-22a074caa71723b35c3a59620f8a2ebdbf290388.zip
Update pt/configure_proxy until it stops segfaulting
Diffstat (limited to 'src/test/test_pt.c')
-rw-r--r--src/test/test_pt.c30
1 files changed, 24 insertions, 6 deletions
diff --git a/src/test/test_pt.c b/src/test/test_pt.c
index 6648326e3f..162d9e3da0 100644
--- a/src/test/test_pt.c
+++ b/src/test/test_pt.c
@@ -10,6 +10,7 @@
#include "transports.h"
#include "circuitbuild.h"
#include "util.h"
+#include "statefile.h"
#include "test.h"
static void
@@ -156,14 +157,14 @@ test_pt_protocol(void)
}
#ifdef _WIN32
-static smartlist_t *
-tor_get_lines_from_handle_replacement(HANDLE *handle,
- enum stream_status *stream_status_out)
+#define STDIN_HANDLE HANDLE
#else
+#define STDIN_HANDLE FILE
+#endif
+
static smartlist_t *
-tor_get_lines_from_handle_replacement(FILE *handle,
+tor_get_lines_from_handle_replacement(STDIN_HANDLE *handle,
enum stream_status *stream_status_out)
-#endif
{
(void) handle;
(void) stream_status_out;
@@ -188,7 +189,16 @@ static void
tor_process_handle_destroy_replacement(process_handle_t *process_handle,
int also_terminate_process)
{
- return;
+ (void) process_handle;
+ (void) also_terminate_process;
+}
+
+static or_state_t *dummy_state = NULL;
+
+static or_state_t *
+get_or_state_replacement(void)
+{
+ return dummy_state;
}
/* Test the configure_proxy() function. */
@@ -199,16 +209,22 @@ test_pt_configure_proxy(void *arg)
int i;
managed_proxy_t *mp = NULL;
+ dummy_state = tor_malloc_zero(sizeof(or_state_t));
+
MOCK(tor_get_lines_from_handle,
tor_get_lines_from_handle_replacement);
MOCK(tor_process_handle_destroy,
tor_process_handle_destroy_replacement);
+ MOCK(get_or_state,
+ get_or_state_replacement);
mp = tor_malloc(sizeof(managed_proxy_t));
mp->conf_state = PT_PROTO_ACCEPTING_METHODS;
mp->transports = smartlist_new();
mp->transports_to_launch = smartlist_new();
mp->process_handle = tor_malloc_zero(sizeof(process_handle_t));
+ mp->argv = tor_malloc_zero(sizeof(char*)*2);
+ mp->argv[0] = tor_strdup("<testcase>");
/* Test the return value of configure_proxy() by calling it some
times while it is uninitialized and then finally finalizing its
@@ -219,9 +235,11 @@ test_pt_configure_proxy(void *arg)
test_assert(configure_proxy(mp) == 1);
done:
+ tor_free(dummy_state);
UNMOCK(tor_get_lines_from_handle);
UNMOCK(tor_process_handle_destroy);
}
+
#define PT_LEGACY(name) \
{ #name, legacy_test_helper, 0, &legacy_setup, test_pt_ ## name }