mirror of
https://github.com/samba-team/samba.git
synced 2025-02-23 09:57:40 +03:00
added a SMB_QUERY_FILE_ALL_INFO test into smbtorture
W95 doesn't seem to support this call.
This commit is contained in:
parent
89141de14e
commit
162947c6e6
@ -995,6 +995,62 @@ BOOL cli_qpathinfo(struct cli_state *cli, char *fname,
|
||||
return True;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
send a qpathinfo call with the SMB_QUERY_FILE_ALL_INFO info level
|
||||
****************************************************************************/
|
||||
BOOL cli_qpathinfo2(struct cli_state *cli, char *fname,
|
||||
time_t *c_time, time_t *a_time, time_t *m_time,
|
||||
time_t *w_time, uint32 *size)
|
||||
{
|
||||
int data_len = 0;
|
||||
int param_len = 0;
|
||||
uint16 setup = TRANSACT2_QPATHINFO;
|
||||
pstring param;
|
||||
char *rparam=NULL, *rdata=NULL;
|
||||
|
||||
param_len = strlen(fname) + 7;
|
||||
|
||||
memset(param, 0, param_len);
|
||||
SSVAL(param, 0, SMB_QUERY_FILE_ALL_INFO);
|
||||
pstrcpy(¶m[6], fname);
|
||||
|
||||
if (!cli_send_trans(cli, SMBtrans2, NULL, -1, 0,
|
||||
NULL, param, &setup,
|
||||
data_len, param_len, 1,
|
||||
cli->max_xmit, 10, 0)) {
|
||||
return False;
|
||||
}
|
||||
|
||||
if (!cli_receive_trans(cli, SMBtrans2, &data_len, ¶m_len,
|
||||
&rdata, &rparam)) {
|
||||
return False;
|
||||
}
|
||||
|
||||
if (!rdata || data_len < 22) {
|
||||
return False;
|
||||
}
|
||||
|
||||
if (c_time) {
|
||||
*c_time = interpret_long_date(rdata+0) - cli->serverzone;
|
||||
}
|
||||
if (a_time) {
|
||||
*a_time = interpret_long_date(rdata+8) - cli->serverzone;
|
||||
}
|
||||
if (m_time) {
|
||||
*m_time = interpret_long_date(rdata+16) - cli->serverzone;
|
||||
}
|
||||
if (w_time) {
|
||||
*w_time = interpret_long_date(rdata+24) - cli->serverzone;
|
||||
}
|
||||
if (size) {
|
||||
*size = IVAL(rdata, 40);
|
||||
}
|
||||
|
||||
if (rdata) free(rdata);
|
||||
if (rparam) free(rparam);
|
||||
return True;
|
||||
}
|
||||
|
||||
|
||||
/****************************************************************************
|
||||
send a qfileinfo call
|
||||
|
@ -690,7 +690,7 @@ static void run_trans2test(void)
|
||||
static struct cli_state cli;
|
||||
int fnum;
|
||||
uint32 size;
|
||||
time_t c_time, a_time, m_time;
|
||||
time_t c_time, a_time, m_time, w_time;
|
||||
char *fname = "\\trans2.tst";
|
||||
|
||||
printf("staring trans2 test\n");
|
||||
@ -732,7 +732,20 @@ static void run_trans2test(void)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
cli_unlink(&cli, fname);
|
||||
fnum = cli_open(&cli, fname,
|
||||
O_RDWR | O_CREAT | O_TRUNC, DENY_NONE);
|
||||
cli_close(&cli, fnum);
|
||||
if (!cli_qpathinfo2(&cli, fname, &c_time, &a_time, &m_time,
|
||||
&w_time, &size)) {
|
||||
printf("ERROR: qpathinfo2 failed (%s)\n", cli_errstr(&cli));
|
||||
} else {
|
||||
if (w_time < 60*60*24*2) {
|
||||
printf("write time=%s", ctime(&w_time));
|
||||
printf("This system appears to set a initial 0 write time\n");
|
||||
}
|
||||
}
|
||||
|
||||
close_connection(&cli);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user