1<testcase>
2# Based on test900
3# N.B. --libcurl output not sufficient to deal with uploaded files.
4<info>
5<keywords>
6SMTP
7--libcurl
8</keywords>
9</info>
10
11#
12# Server-side
13<reply>
14<servercmd>
15CAPA SIZE
16</servercmd>
17</reply>
18
19#
20# Client-side
21<client>
22<server>
23smtp
24</server>
25 <name>
26--libcurl for SMTP
27 </name>
28<file name="log/test1406.eml">
29From: different
30To: another
31
32body
33</file>
34 <command>
35smtp://%HOSTIP:%SMTPPORT/1406 --mail-rcpt recipient.one@example.com --mail-rcpt recipient.two@example.com --mail-from sender@example.com -T log/test1406.eml --libcurl log/test1406.c
36</command>
37</client>
38
39#
40# Verify data after the test has been "shot"
41<verify>
42<protocol>
43EHLO 1406
44MAIL FROM:<sender@example.com> SIZE=38
45RCPT TO:<recipient.one@example.com>
46RCPT TO:<recipient.two@example.com>
47DATA
48QUIT
49</protocol>
50<upload>
51From: different
52To: another
53
54body
55.
56</upload>
57<file name="log/test1406.c" mode="text">
58/********* Sample code generated by the curl command line tool **********
59 * All curl_easy_setopt() options are documented at:
60 * https://curl.haxx.se/libcurl/c/curl_easy_setopt.html
61 ************************************************************************/
62#include <curl/curl.h>
63
64int main(int argc, char *argv[])
65{
66  CURLcode ret;
67  CURL *hnd;
68  struct curl_slist *slist1;
69
70  slist1 = NULL;
71  slist1 = curl_slist_append(slist1, "recipient.one@example.com");
72  slist1 = curl_slist_append(slist1, "recipient.two@example.com");
73
74  hnd = curl_easy_init();
75  curl_easy_setopt(hnd, CURLOPT_INFILESIZE_LARGE, (curl_off_t)38);
76  curl_easy_setopt(hnd, CURLOPT_URL, "smtp://%HOSTIP:%SMTPPORT/1406");
77  curl_easy_setopt(hnd, CURLOPT_HEADER, 1L);
78  curl_easy_setopt(hnd, CURLOPT_UPLOAD, 1L);
79  curl_easy_setopt(hnd, CURLOPT_USERAGENT, "stripped");
80  curl_easy_setopt(hnd, CURLOPT_MAXREDIRS, 50L);
81  curl_easy_setopt(hnd, CURLOPT_VERBOSE, 1L);
82  curl_easy_setopt(hnd, CURLOPT_TCP_KEEPALIVE, 1L);
83  curl_easy_setopt(hnd, CURLOPT_MAIL_FROM, "sender@example.com");
84  curl_easy_setopt(hnd, CURLOPT_MAIL_RCPT, slist1);
85
86  /* Here is a list of options the curl code used that cannot get generated
87     as source easily. You may select to either not use them or implement
88     them yourself.
89
90  CURLOPT_WRITEDATA set to a objectpointer
91  CURLOPT_WRITEFUNCTION set to a functionpointer
92  CURLOPT_READDATA set to a objectpointer
93  CURLOPT_READFUNCTION set to a functionpointer
94  CURLOPT_SEEKDATA set to a objectpointer
95  CURLOPT_SEEKFUNCTION set to a functionpointer
96  CURLOPT_ERRORBUFFER set to a objectpointer
97  CURLOPT_STDERR set to a objectpointer
98  CURLOPT_DEBUGFUNCTION set to a functionpointer
99  CURLOPT_DEBUGDATA set to a objectpointer
100  CURLOPT_HEADERFUNCTION set to a functionpointer
101  CURLOPT_HEADERDATA set to a objectpointer
102
103  */
104
105  ret = curl_easy_perform(hnd);
106
107  curl_easy_cleanup(hnd);
108  hnd = NULL;
109  curl_slist_free_all(slist1);
110  slist1 = NULL;
111
112  return (int)ret;
113}
114/**** End of sample code ****/
115</file>
116<stripfile>
117# curl's default user-agent varies with version, libraries etc.
118s/(USERAGENT, \")[^\"]+/${1}stripped/
119# CURLOPT_SSL_VERIFYPEER, SSH_KNOWNHOSTS and HTTP_VERSION vary with
120# configurations - just ignore them
121$_ = '' if /CURLOPT_SSL_VERIFYPEER/
122$_ = '' if /CURLOPT_SSH_KNOWNHOSTS/
123$_ = '' if /CURLOPT_HTTP_VERSION/
124</stripfile>
125</verify>
126</testcase>
127