]> git.proxmox.com Git - mirror_lxc.git/blobdiff - src/tests/snapshot.c
spelling: userns
[mirror_lxc.git] / src / tests / snapshot.c
index b035096f1b4600df4bc8c218acb1223033b74db6..1b7d7ab448baa4b54a9a6c31350866e21202747d 100644 (file)
 static void try_to_remove(void)
 {
        struct lxc_container *c;
+
        c = lxc_container_new(RESTNAME, NULL);
        if (c) {
                c->snapshot_destroy_all(c);
                if (c->is_defined(c))
                        c->destroy(c);
+
                lxc_container_put(c);
        }
+
        c = lxc_container_new(MYNAME2, NULL);
        if (c) {
                c->destroy_with_snapshots(c);
                lxc_container_put(c);
        }
+
        c = lxc_container_new(MYNAME, NULL);
        if (c) {
                c->snapshot_destroy_all(c);
                if (c->is_defined(c))
                        c->destroy(c);
+
                lxc_container_put(c);
        }
 }
 
 int main(int argc, char *argv[])
 {
+       int i, n, ret;
+       char path[1024];
+       struct stat sb;
+       struct lxc_snapshot *s;
        struct lxc_container *c, *c2 = NULL;
        char *template = "busybox";
 
@@ -62,6 +71,7 @@ int main(int argc, char *argv[])
                template = argv[1];
 
        try_to_remove();
+
        c = lxc_container_new(MYNAME, NULL);
        if (!c) {
                fprintf(stderr, "%s: %d: failed to load first container\n", __FILE__, __LINE__);
@@ -72,15 +82,19 @@ int main(int argc, char *argv[])
                fprintf(stderr, "%d: %s thought it was defined\n", __LINE__, MYNAME);
                (void) c->destroy_with_snapshots(c);
        }
-       if (!c->set_config_item(c, "lxc.network.type", "empty")) {
+
+       if (!c->set_config_item(c, "lxc.net.0.type", "empty")) {
                fprintf(stderr, "%s: %d: failed to set network type\n", __FILE__, __LINE__);
                goto err;
        }
+
        c->save_config(c, NULL);
+
        if (!c->createl(c, template, NULL, NULL, 0, NULL)) {
                fprintf(stderr, "%s: %d: failed to create %s container\n", __FILE__, __LINE__, template);
                goto err;
        }
+
        c->load_config(c, NULL);
 
        if (c->snapshot(c, NULL) != 0) {
@@ -89,31 +103,31 @@ int main(int argc, char *argv[])
        }
 
        // rootfs should be ${lxcpath}${lxcname}/snaps/snap0/rootfs
-       struct stat sb;
-       int ret;
-       char path[1024];
-       snprintf(path, 1024, "%s/%s/snaps/snap0/rootfs", lxc_get_global_config_item("lxc.lxcpath"), MYNAME);
+       ret = snprintf(path, 1024, "%s/%s/snaps/snap0/rootfs", lxc_get_global_config_item("lxc.lxcpath"), MYNAME);
+       if (ret < 0 || (size_t)ret >= 1024) {
+               fprintf(stderr, "%s: %d: failed to create string\n", __FILE__, __LINE__);
+               goto err;
+       }
+
        ret = stat(path, &sb);
        if (ret != 0) {
                fprintf(stderr, "%s: %d: snapshot was not actually created\n", __FILE__, __LINE__);
                goto err;
        }
 
-       struct lxc_snapshot *s;
-       int i, n;
-
        n = c->snapshot_list(c, &s);
        if (n < 1) {
                fprintf(stderr, "%s: %d: failed listing containers\n", __FILE__, __LINE__);
                goto err;
        }
+
        if (strcmp(s->name, "snap0") != 0) {
                fprintf(stderr, "%s: %d: snapshot had bad name\n", __FILE__, __LINE__);
                goto err;
        }
-       for (i=0; i<n; i++) {
+
+       for (i=0; i<n; i++)
                s[i].free(&s[i]);
-       }
        free(s);
 
        if (!c->snapshot_restore(c, "snap0", RESTNAME)) {
@@ -149,13 +163,14 @@ int main(int argc, char *argv[])
                fprintf(stderr, "%s: %d: failed listing containers\n", __FILE__, __LINE__);
                goto err;
        }
+
        if (strcmp(s->name, "snap0") != 0) {
                fprintf(stderr, "%s: %d: snapshot had bad name\n", __FILE__, __LINE__);
                goto err;
        }
-       for (i=0; i<n; i++) {
+
+       for (i=0; i<n; i++)
                s[i].free(&s[i]);
-       }
        free(s);
 
        if (!c2->snapshot_restore(c2, "snap0", NULL)) {
@@ -174,6 +189,7 @@ good:
 
        printf("All tests passed\n");
        exit(0);
+
 err:
        lxc_container_put(c);
        try_to_remove();