Exhaustive test coverage to test the usage of sort,order and limit parameter for the browse middleware

This commit is contained in:
Karthic Rao 2015-10-09 11:28:11 +05:30
parent 02c7770b57
commit f5cd4f17f8
3 changed files with 118 additions and 39 deletions

View file

@ -242,24 +242,31 @@ func (b Browse) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
listing.Sort, listing.Order = r.URL.Query().Get("sort"), r.URL.Query().Get("order") listing.Sort, listing.Order = r.URL.Query().Get("sort"), r.URL.Query().Get("order")
// If the query 'sort' or 'order' is empty, check the cookies // If the query 'sort' or 'order' is empty, check the cookies
if listing.Sort == "" || listing.Order == "" { if listing.Sort == "" {
sortCookie, sortErr := r.Cookie("sort") sortCookie, sortErr := r.Cookie("sort")
orderCookie, orderErr := r.Cookie("order")
// if there's no sorting values in the cookies, default to "name" and "asc" // if there's no sorting values in the cookies, default to "name" and "asc"
if sortErr != nil || orderErr != nil { if sortErr != nil {
listing.Sort = "name" listing.Sort = "name"
listing.Order = "asc"
} else { // if we have values in the cookies, use them } else { // if we have values in the cookies, use them
listing.Sort = sortCookie.Value listing.Sort = sortCookie.Value
listing.Order = orderCookie.Value
} }
} else { // save the query value of 'sort' and 'order' as cookies } else { // save the query value of 'sort' and 'order' as cookies
http.SetCookie(w, &http.Cookie{Name: "sort", Value: listing.Sort, Path: "/"}) http.SetCookie(w, &http.Cookie{Name: "sort", Value: listing.Sort, Path: "/"})
http.SetCookie(w, &http.Cookie{Name: "order", Value: listing.Order, Path: "/"}) http.SetCookie(w, &http.Cookie{Name: "order", Value: listing.Order, Path: "/"})
} }
if listing.Order == "" {
orderCookie, orderErr := r.Cookie("order")
// if there's no sorting values in the cookies, default to "name" and "asc"
if orderErr != nil {
listing.Order = "asc"
} else { // if we have values in the cookies, use them
listing.Order = orderCookie.Value
}
} else { // save the query value of 'sort' and 'order' as cookies
http.SetCookie(w, &http.Cookie{Name: "order", Value: listing.Order, Path: "/"})
}
// Apply the sorting // Apply the sorting
listing.applySort() listing.applySort()

View file

@ -129,9 +129,9 @@ func TestBrowseTemplate(t *testing.T) {
rec := httptest.NewRecorder() rec := httptest.NewRecorder()
b.ServeHTTP(rec, req) code, err := b.ServeHTTP(rec, req)
if rec.Code != http.StatusOK { if code != http.StatusOK {
t.Fatalf("Wrong status, expected %d, got %d", http.StatusOK, rec.Code) t.Fatalf("Wrong status, expected %d, got %d", http.StatusOK, code)
} }
respBody := rec.Body.String() respBody := rec.Body.String()
@ -149,6 +149,8 @@ func TestBrowseTemplate(t *testing.T) {
<a href="test2.html">test2.html</a><br> <a href="test2.html">test2.html</a><br>
<a href="test3.html">test3.html</a><br>
</body> </body>
</html> </html>
` `
@ -169,30 +171,13 @@ func TestBrowseJson(t *testing.T) {
Root: "./testdata", Root: "./testdata",
Configs: []Config{ Configs: []Config{
Config{ Config{
PathScope: "/photos", PathScope: "/photos/",
}, },
}, },
} }
req, err := http.NewRequest("GET", "/photos/", nil) //Getting the listing from the ./testdata/photos, the listing returned will be used to validate test results
if err != nil { file, err := os.Open(b.Root + "/photos")
t.Fatalf("Test: Could not create HTTP request: %v", err)
}
req.Header.Set("Accept", "application/json")
rec := httptest.NewRecorder()
b.ServeHTTP(rec, req)
if rec.Code != http.StatusOK {
t.Fatalf("Wrong status, expected %d, got %d", http.StatusOK, rec.Code)
}
if rec.HeaderMap.Get("Content-Type") != "application/json; charset=utf-8" {
t.Fatalf("Expected Content type to be application/json; charset=utf-8, but got %s ", rec.HeaderMap.Get("Content-Type"))
}
actualJsonResponseString := rec.Body.String()
//generating the listing to compare it with the response body
file, err := os.Open(b.Root + req.URL.Path)
if err != nil { if err != nil {
if os.IsPermission(err) { if os.IsPermission(err) {
t.Fatalf("Os Permission Error") t.Fatalf("Os Permission Error")
@ -207,6 +192,7 @@ func TestBrowseJson(t *testing.T) {
t.Fatalf("Unable to Read Contents of the directory") t.Fatalf("Unable to Read Contents of the directory")
} }
var fileinfos []FileInfo var fileinfos []FileInfo
for _, f := range files { for _, f := range files {
name := f.Name() name := f.Name()
@ -228,16 +214,99 @@ func TestBrowseJson(t *testing.T) {
listing := Listing{ listing := Listing{
Items: fileinfos, Items: fileinfos,
} }
listing.Sort = "name" //listing obtained above and will be used for validation inside the tests
listing.Order = "asc"
listing.applySort()
marsh, err := json.Marshal(listing.Items) tests := []struct {
if err != nil { QueryUrl string
t.Fatalf("Unable to Marshal the listing ") SortBy string
OrderBy string
Limit int
shouldErr bool
expectedResult []FileInfo
}{
//test case 1: testing for default sort and order and without the limit parameter, default sort is by name and the default order is ascending
//without the limit query entire listing will be produced
{"/", "", "", -1, false, listing.Items},
//test case 2: limit is set to 1, orderBy and sortBy is default
{"/?limit=1", "", "", 1, false, listing.Items[:1]},
//test case 3 : if the listing request is bigger than total size of listing then it should return everything
{"/?limit=100000000", "", "", 100000000, false, listing.Items},
//testing for negative limit
{"/?limit=-1", "", "", -1, false, listing.Items},
//testing with limit set to -1 and order set to descending
{"/?limit=-1&order=desc", "", "desc", -1, false, listing.Items},
//testing with limit set to 2 and order set to descending
{"/?limit=2&order=desc", "", "desc", 2, false, listing.Items},
//testing with limit set to 3 and order set to descending
{"/?limit=3&order=desc", "", "desc", 3, false, listing.Items},
//testing with limit set to 3 and order set to ascending
{"/?limit=3&order=asc", "", "asc", 3, false, listing.Items},
//testing with limit set to 1111111 and order set to ascending
{"/?limit=1111111&order=asc", "", "asc", 1111111, false, listing.Items},
//testing with limit set to default and order set to ascending and sorting by size
{"/?order=asc&sort=size", "size", "asc", -1, false, listing.Items},
//testing with limit set to default and order set to ascending and sorting by last modified
{"/?order=asc&sort=time", "time", "asc", -1, false, listing.Items},
//testing with limit set to 1 and order set to ascending and sorting by last modified
{"/?order=asc&sort=time&limit=1", "time", "asc", 1, false, listing.Items},
//testing with limit set to -100 and order set to ascending and sorting by last modified
{"/?order=asc&sort=time&limit=-100", "time", "asc", -100, false, listing.Items},
//testing with limit set to -100 and order set to ascending and sorting by size
{"/?order=asc&sort=size&limit=-100", "size", "asc", -100, false, listing.Items},
} }
expectedJsonString := string(marsh)
if actualJsonResponseString != expectedJsonString { for i, test := range tests {
t.Errorf("Json response string doesnt match the expected Json response ") var marsh []byte
req, err := http.NewRequest("GET", "/photos"+test.QueryUrl, nil)
if err == nil && test.shouldErr {
t.Errorf("Test %d didn't error, but it should have", i)
} else if err != nil && !test.shouldErr {
t.Errorf("Test %d errored, but it shouldn't have; got '%v'", i, err)
}
req.Header.Set("Accept", "application/json")
rec := httptest.NewRecorder()
code, err := b.ServeHTTP(rec, req)
if code != http.StatusOK {
t.Fatalf("Wrong status, expected %d, got %d", http.StatusOK, code)
}
if rec.HeaderMap.Get("Content-Type") != "application/json; charset=utf-8" {
t.Fatalf("Expected Content type to be application/json; charset=utf-8, but got %s ", rec.HeaderMap.Get("Content-Type"))
}
actualJsonResponseString := rec.Body.String()
copyOflisting := listing
if test.SortBy == "" {
copyOflisting.Sort = "name"
} else {
copyOflisting.Sort = test.SortBy
}
if test.OrderBy == "" {
copyOflisting.Order = "asc"
} else {
copyOflisting.Order = test.OrderBy
}
copyOflisting.applySort()
limit := test.Limit
if limit <= len(copyOflisting.Items) && limit > 0 {
marsh, err = json.Marshal(copyOflisting.Items[:limit])
} else { // if the 'limit' query is empty, or has the wrong value, list everything
marsh, err = json.Marshal(copyOflisting.Items)
}
if err != nil {
t.Fatalf("Unable to Marshal the listing ")
}
expectedJsonString := string(marsh)
if actualJsonResponseString != expectedJsonString {
t.Errorf("Json response string doesnt match the expected Json response for test number %d with sort = %s , order = %s,\nExpected response %s\nActual response = %s\n ", i+1, test.SortBy, test.OrderBy, expectedJsonString, actualJsonResponseString)
}
} }
} }

View file

@ -0,0 +1,3 @@
<!DOCTYPE html>
<html>
</html>