s3: Factor out torture_setup_unix_extensions
authorVolker Lendecke <vl@samba.org>
Sun, 29 Nov 2009 15:04:21 +0000 (16:04 +0100)
committerVolker Lendecke <vl@samba.org>
Sun, 29 Nov 2009 15:12:51 +0000 (16:12 +0100)
source3/torture/proto.h
source3/torture/torture.c

index 5d7504abfd89c33af1591a09014fd20e2e8f16ea..56396fe4c07a33d59dab598faff50a004d668fb7 100644 (file)
@@ -70,6 +70,7 @@ bool torture_cli_session_setup2(struct cli_state *cli, uint16 *new_vuid);
 bool torture_close_connection(struct cli_state *c);
 bool torture_ioctl_test(int dummy);
 bool torture_chkpath_test(int dummy);
+NTSTATUS torture_setup_unix_extensions(struct cli_state *cli);
 
 /* The following definitions come from torture/utable.c  */
 
index 39f555906696d2b3ac828f3fb261c1515581366a..4b5e8b2dfb847e1f88cb2859aa9e95df1372b210 100644 (file)
@@ -4347,6 +4347,36 @@ static bool run_opentest(int dummy)
        return correct;
 }
 
+NTSTATUS torture_setup_unix_extensions(struct cli_state *cli)
+{
+       uint16 major, minor;
+       uint32 caplow, caphigh;
+       NTSTATUS status;
+
+       if (!SERVER_HAS_UNIX_CIFS(cli)) {
+               printf("Server doesn't support UNIX CIFS extensions.\n");
+               return NT_STATUS_NOT_SUPPORTED;
+       }
+
+       status = cli_unix_extensions_version(cli, &major, &minor, &caplow,
+                                            &caphigh);
+       if (!NT_STATUS_IS_OK(status)) {
+               printf("Server didn't return UNIX CIFS extensions: %s\n",
+                      nt_errstr(status));
+               return status;
+       }
+
+       status = cli_set_unix_extensions_capabilities(cli, major, minor,
+                                                     caplow, caphigh);
+       if (!NT_STATUS_IS_OK(status)) {
+               printf("Server doesn't support setting UNIX CIFS extensions: "
+                      "%s.\n", nt_errstr(status));
+               return status;
+        }
+
+       return NT_STATUS_OK;
+}
+
 /*
   Test POSIX open /mkdir calls.
  */
@@ -4359,8 +4389,6 @@ static bool run_simple_posix_open_test(int dummy)
        const char *dname = "posix:dir";
        char buf[10];
        char namebuf[11];
-       uint16 major, minor;
-       uint32 caplow, caphigh;
        uint16_t fnum1 = (uint16_t)-1;
        SMB_STRUCT_STAT sbuf;
        bool correct = false;
@@ -4374,27 +4402,11 @@ static bool run_simple_posix_open_test(int dummy)
 
        cli_sockopt(cli1, sockops);
 
-       if (!SERVER_HAS_UNIX_CIFS(cli1)) {
-               printf("Server doesn't support UNIX CIFS extensions.\n");
-               return false;
-       }
-
-       status = cli_unix_extensions_version(cli1, &major, &minor, &caplow,
-                                            &caphigh);
+       status = torture_setup_unix_extensions(cli1);
        if (!NT_STATUS_IS_OK(status)) {
-               printf("Server didn't return UNIX CIFS extensions: %s\n",
-                      nt_errstr(status));
                return false;
        }
 
-       status = cli_set_unix_extensions_capabilities(cli1, major, minor,
-                                                     caplow, caphigh);
-       if (!NT_STATUS_IS_OK(status)) {
-               printf("Server doesn't support setting UNIX CIFS extensions: "
-                      "%s.\n", nt_errstr(status));
-               return false;
-        }
-
        cli_setatr(cli1, fname, 0, 0);
        cli_posix_unlink(cli1, fname);
        cli_setatr(cli1, dname, 0, 0);