Add ServerById() function and acceptance test.
diff --git a/acceptance/02-list-servers.go b/acceptance/02-list-servers.go
index bd1da3c..acfc802 100644
--- a/acceptance/02-list-servers.go
+++ b/acceptance/02-list-servers.go
@@ -4,8 +4,11 @@
 	"fmt"
 	"github.com/rackspace/gophercloud"
 	"os"
+	"flag"
 )
 
+var quiet = flag.Bool("quiet", false, "Quiet mode, for acceptance testing.  $? still indicates errors though.")
+
 func main() {
 	provider := os.Getenv("SDK_PROVIDER")
 	username := os.Getenv("SDK_USERNAME")
@@ -19,6 +22,8 @@
 		os.Exit(1)
 	}
 
+	flag.Parse()
+
 	acc, err := gophercloud.Authenticate(
 		provider,
 		gophercloud.AuthOptions{
@@ -45,9 +50,9 @@
 		panic(err)
 	}
 
-	fmt.Println("Server ID")
-	fmt.Println("----------------------------------------")
-	for _, s := range servers {
-		fmt.Printf("	%s\n", s.Id)
+	if !*quiet {
+		for _, s := range servers {
+			fmt.Printf("%s\n", s.Id)
+		}
 	}
 }
diff --git a/acceptance/03-get-server-details.go b/acceptance/03-get-server-details.go
new file mode 100644
index 0000000..6d826db
--- /dev/null
+++ b/acceptance/03-get-server-details.go
@@ -0,0 +1,107 @@
+package main
+
+import (
+	"fmt"
+	"flag"
+	"github.com/rackspace/gophercloud"
+	"os"
+)
+
+var id = flag.String("i", "", "Server ID to get info on.  Defaults to first server in your account if unspecified.")
+var rgn = flag.String("r", "DFW", "Datacenter region")
+var quiet = flag.Bool("quiet", false, "Run quietly, for acceptance testing.  $? non-zero if issue.")
+
+func main() {
+	provider := os.Getenv("SDK_PROVIDER")
+	username := os.Getenv("SDK_USERNAME")
+	password := os.Getenv("SDK_PASSWORD")
+
+	if (provider == "") || (username == "") || (password == "") {
+		fmt.Fprintf(os.Stderr, "One or more of the following environment variables aren't set:\n")
+		fmt.Fprintf(os.Stderr, "	SDK_PROVIDER=\"%s\"\n", provider)
+		fmt.Fprintf(os.Stderr, "	SDK_USERNAME=\"%s\"\n", username)
+		fmt.Fprintf(os.Stderr, "	SDK_PASSWORD=\"%s\"\n", password)
+		os.Exit(1)
+	}
+
+	flag.Parse()
+
+	auth, err := gophercloud.Authenticate(
+		provider,
+		gophercloud.AuthOptions{
+			Username: username,
+			Password: password,
+		},
+	)
+	if err != nil {
+		panic(err)
+	}
+
+	servers, err := gophercloud.ServersApi(auth, gophercloud.ApiCriteria{
+		Name:      "cloudServersOpenStack",
+		Region:    *rgn,
+		VersionId: "2",
+		UrlChoice: gophercloud.PublicURL,
+	})
+	if err != nil {
+		panic(err)
+	}
+
+	serverId := ""
+	if *id == "" {
+		ss, err := servers.ListServers()
+		if err != nil {
+			panic(err)
+		}
+		// We could just cheat and dump the server details from ss[0].
+		// But, that tests ListServers(), and not ServerById().  So, we
+		// elect not to cheat.
+		serverId = ss[0].Id
+	} else {
+		serverId = *id
+	}
+
+	s, err := servers.ServerById(serverId)
+	if err != nil {
+		panic(err)
+	}
+
+	configs := []string {
+		"Access IPv4: %s\n",
+		"Access IPv6: %s\n",
+		"    Created: %s\n",
+		"     Flavor: %s\n",
+		"    Host ID: %s\n",
+		"         ID: %s\n",
+		"      Image: %s\n",
+		"       Name: %s\n",
+		"   Progress: %s\n",
+		"     Status: %s\n",
+		"  Tenant ID: %s\n",
+		"    Updated: %s\n",
+		"    User ID: %s\n",
+	}
+
+	values := []string {
+		s.AccessIPv4,
+		s.AccessIPv6,
+		s.Created,
+		s.Flavor.Id,
+		s.HostId,
+		s.Id,
+		s.Image.Id,
+		s.Name,
+		fmt.Sprintf("%d", s.Progress),
+		s.Status,
+		s.TenantId,
+		s.Updated,
+		s.UserId,
+	}
+
+	if !*quiet {
+		fmt.Println("Server info:")
+		for i, _ := range configs {
+			fmt.Printf(configs[i], values[i])
+		}
+	}
+}
diff --git a/interfaces.go b/interfaces.go
index de2c35b..16c0589 100644
--- a/interfaces.go
+++ b/interfaces.go
@@ -19,4 +19,5 @@
 // for your provider.
 type CloudServersProvider interface {
 	ListServers() ([]Server, error)
+	ServerById(id string) (*Server, error)
 }
diff --git a/servers.go b/servers.go
index 586df8d..ee67823 100644
--- a/servers.go
+++ b/servers.go
@@ -37,6 +37,20 @@
 	return ss, err
 }
 
+// See the CloudServersProvider interface for details.
+func (gsp *genericServersProvider) ServerById(id string) (*Server, error) {
+	var s *Server
+
+	url := gsp.endpoint + "/servers/" + id
+	err := perigee.Get(url, perigee.Options{
+		Results: &struct{ Server **Server }{&s},
+		MoreHeaders: map[string]string{
+			"X-Auth-Token": gsp.access.AuthToken(),
+		},
+	})
+	return s, err
+}
+
 // RaxBandwidth provides measurement of server bandwidth consumed over a given audit interval.
 type RaxBandwidth struct {
 	AuditPeriodEnd    string `json:"audit_period_end"`