Test Username+DomainID+Password auth.
diff --git a/openstack/identity/v3/tokens/requests.go b/openstack/identity/v3/tokens/requests.go
index 1790df5..955db87 100644
--- a/openstack/identity/v3/tokens/requests.go
+++ b/openstack/identity/v3/tokens/requests.go
@@ -17,7 +17,7 @@
 func Create(c *gophercloud.ServiceClient, scope *Scope) (gophercloud.AuthResults, error) {
 	type domainReq struct {
 		ID   *string `json:"id,omitempty"`
-		Name *string `json:"id,omitempty"`
+		Name *string `json:"name,omitempty"`
 	}
 
 	type projectReq struct {
diff --git a/openstack/identity/v3/tokens/requests_test.go b/openstack/identity/v3/tokens/requests_test.go
index bbe1448..64d6dbb 100644
--- a/openstack/identity/v3/tokens/requests_test.go
+++ b/openstack/identity/v3/tokens/requests_test.go
@@ -9,38 +9,63 @@
 	"github.com/rackspace/gophercloud/testhelper"
 )
 
-func TestCreateUserIDAndPassword(t *testing.T) {
+// authTokenPost verifies that providing certain AuthOptions and Scope results in an expected JSON structure.
+func authTokenPost(t *testing.T, options gophercloud.AuthOptions, scope *Scope, requestJSON string) {
 	setup()
 	defer teardown()
 
 	client := gophercloud.ServiceClient{
 		Endpoint: endpoint(),
-		Options:  gophercloud.AuthOptions{UserID: "me", Password: "squirrel!"},
+		Options:  options,
 	}
 
 	mux.HandleFunc("/auth/tokens", func(w http.ResponseWriter, r *http.Request) {
 		testhelper.TestMethod(t, r, "POST")
 		testhelper.TestHeader(t, r, "Content-Type", "application/json")
 		testhelper.TestHeader(t, r, "Accept", "application/json")
-
-		testhelper.TestJSONRequest(t, r, `
-			{
-				"auth": {
-					"identity": {
-						"methods": ["password"],
-						"password": {
-							"user": { "id": "me", "password": "squirrel!" }
-						}
-					}
-				}
-			}
-		`)
+		testhelper.TestJSONRequest(t, r, requestJSON)
 
 		fmt.Fprintf(w, `{}`)
 	})
 
-	_, err := Create(&client, nil)
+	_, err := Create(&client, scope)
 	if err != nil {
 		t.Errorf("Create returned an error: %v", err)
 	}
 }
+
+func TestCreateUserIDAndPassword(t *testing.T) {
+	authTokenPost(t, gophercloud.AuthOptions{UserID: "me", Password: "squirrel!"}, nil, `
+		{
+			"auth": {
+				"identity": {
+					"methods": ["password"],
+					"password": {
+						"user": { "id": "me", "password": "squirrel!" }
+					}
+				}
+			}
+		}
+	`)
+}
+
+func TestCreateUsernameDomainIDPassword(t *testing.T) {
+	authTokenPost(t, gophercloud.AuthOptions{Username: "fakey", Password: "notpassword", DomainID: "abc123"}, nil, `
+		{
+			"auth": {
+				"identity": {
+					"methods": ["password"],
+					"password": {
+						"user": {
+							"domain": {
+								"id": "abc123"
+							},
+							"name": "fakey",
+							"password": "notpassword"
+						}
+					}
+				}
+			}
+		}
+	`)
+}