summaryrefslogtreecommitdiff
path: root/tests/ConnectionHandlerTest/ConnectionHandlerTest.cc
blob: 89dc56d5a616c3aca2940066cc9c5044d17daae1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
/*
 * File:   ConnectionHandlerTest.cc
 * Author: django
 *
 * Created on 10.07.2012, 05:48:23
 */
#include <ConnectionHandler.h>
#include <ServerConfig.h>
#include <FSMediaScanner.h>
#include <MediaFactory.h>
#include <MediaListHandler.h>
#include <MediaFileHandler.h>
#include <CommandHandler.h>
#include <JSonListAssembler.h>
#include <HTMLListAssembler.h>
#include <HTTPRequest.h>
#include <HTTPResponse.h>
#include <TimeMs.h>
#include <stdlib.h>
#include <iostream>
#include <stdio.h>
#include <sys/types.h>

class cTestUnit {
public:
  cTestUnit(const char *Name, cConnectionPoint &cp);
  ~cTestUnit();

  void test1(void);
  void test2(void);

  const char *Name(void) const { return name; }
  void SetUp(void);

private:
  cServerConfig config;
  cConnectionHandler ch;
  const char *name;
  cFSMediaScanner *scanner;
};

cTestUnit::cTestUnit(const char* Name, cConnectionPoint &cp)
 : config("/var/lib/cmp")
 , ch(cp, config)
 , name(Name)
 , scanner(NULL)
{
  config.SetAuthorizationRequired(false);
  config.SetDocumentRoot("/media/video");
  config.SetAppIcon("/media/favicon.ico");

  scanner = new cFSMediaScanner();
  if (!scanner) {
     fprintf(stderr, "could not initialize application! (1)");
     exit(-1);
     }
  scanner->SetMediaFactory(new cMediaFactory(config));

  cAbstractMediaRequestHandler::SetFSMediaScanner(scanner);
  cConnectionHandler::RegisterRequestHandler("/cmd", new cCommandHandler());
  cMediaListHandler *listHandler = new cMediaListHandler();

  listHandler->SetListAssembler("json", new cJSonListAssembler());
  listHandler->SetDefaultListAssembler(new cHTMLListAssembler());
  cConnectionHandler::RegisterRequestHandler("/", listHandler);
  cConnectionHandler::RegisterDefaultHandler(new cMediaFileHandler());
}

cTestUnit::~cTestUnit()
{
  cCommandHandler::Cleanup();
  delete scanner;
}

void cTestUnit::SetUp()
{
  if (scanner) scanner->Refresh();
}

void cTestUnit::test1()
{
  std::cout << "ConnectionHandlerTest test 1" << std::endl;

  cHTTPRequest rq(cHTTPRequest::GET, "/");

  rq.SetHeader("Host", "localhost:43567");
  rq.SetHeader("User-Agent", "TestUnit");
  rq.SetHeader("Accept", "image/png,image/*;q=0.8,*/*;q=0.5");
  rq.SetHeader("Accept-Language", "de-de,de;q=0.8,en-us;q=0.5,en;q=0.3");
  rq.SetHeader("Accept-Encoding", "gzip,deflate");
  rq.SetHeader("Accept-Charset", "ISO-8859-1,utf-8;q=0.7,*;q=0.7");
  rq.SetHeader("Keep-Alive", "300");
  rq.SetHeader("Connection", "keep-alive");

  rq.Dump();
  cHTTPResponse *res = ch.ProcessRequest(rq);

  std::cout << "response looks like ..." << std::endl;
  res->Dump();
  delete res;
}

void cTestUnit::test2()
{
  std::cout << "ConnectionHandlerTest test 2" << std::endl;
  std::cout << "%TEST_FAILED% time=0 testname=test2 (ConnectionHandlerTest) message=error message sample" << std::endl;
}

int main(int argc, char** argv)
{
  uint64_t t0 = cTimeMs::Now();
  cConnectionPoint localHost("localhost", 40902);
  cTestUnit unit("ConnectionHandlerTest", localHost);

  unit.SetUp();
  std::cout << "%SUITE_STARTING% " << unit.Name() << std::endl;
  std::cout << "%SUITE_STARTED%" << std::endl;

  std::cout << "%TEST_STARTED% test1 (" << unit.Name() << ")" << std::endl;
  uint64_t start = cTimeMs::Now();
  unit.test1();
  uint64_t end = cTimeMs::Now();
  std::cout << "%TEST_FINISHED% time=" << (double)(end - start) / 1000 << " test1 (" << unit.Name() << ")" << std::endl;

  std::cout << "%TEST_STARTED% test2 (" << unit.Name() << ")\n" << std::endl;
  start = cTimeMs::Now();
  unit.test2();
  end = cTimeMs::Now();
  std::cout << "%TEST_FINISHED% time=" << (double)(end - start) / 1000 << " test2 (" << unit.Name() << ")" << std::endl;

  std::cout << "%SUITE_FINISHED% time=" << (double)(cTimeMs::Now() - t0) / 1000 << std::endl;

  cFile::Cleanup();
  cUrl::Cleanup();

  return (EXIT_SUCCESS);
}