Create test fixtures (stable test objects)
This commit is contained in:
parent
7f286d0596
commit
35cf1f1296
@ -4,9 +4,9 @@ import (
|
||||
"testing"
|
||||
|
||||
"github.com/go-test/deep"
|
||||
|
||||
)
|
||||
|
||||
|
||||
/**
|
||||
* Create a Tweet, save it, reload it, and make sure it comes back the same
|
||||
*/
|
||||
@ -15,18 +15,11 @@ func TestSaveAndLoadTweet(t *testing.T) {
|
||||
profile := create_or_load_profile(profile_path)
|
||||
|
||||
tweet := create_dummy_tweet()
|
||||
user := create_dummy_user()
|
||||
|
||||
user := create_stable_user()
|
||||
tweet.UserID = user.ID
|
||||
|
||||
// Save the user
|
||||
err := profile.SaveUser(user)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to save the user, so no point in continuing the test: %s", err.Error())
|
||||
}
|
||||
|
||||
// Save the tweet
|
||||
err = profile.SaveTweet(tweet)
|
||||
err := profile.SaveTweet(tweet)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to save the tweet: %s", err.Error())
|
||||
}
|
||||
@ -50,20 +43,14 @@ func TestIsTweetInDatabase(t *testing.T) {
|
||||
profile := create_or_load_profile(profile_path)
|
||||
|
||||
tweet := create_dummy_tweet()
|
||||
user := create_dummy_user()
|
||||
user := create_stable_user()
|
||||
tweet.UserID = user.ID
|
||||
|
||||
// Save the user
|
||||
err := profile.SaveUser(user)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to save the user, so no point in continuing the test: %s", err.Error())
|
||||
}
|
||||
|
||||
exists := profile.IsTweetInDatabase(tweet.ID)
|
||||
if exists {
|
||||
t.Errorf("It shouldn't exist, but it does: %s", tweet.ID)
|
||||
}
|
||||
err = profile.SaveTweet(tweet)
|
||||
err := profile.SaveTweet(tweet)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
@ -81,18 +68,11 @@ func TestLoadUserForTweet(t *testing.T) {
|
||||
profile := create_or_load_profile(profile_path)
|
||||
|
||||
tweet := create_dummy_tweet()
|
||||
user := create_dummy_user()
|
||||
|
||||
user := create_stable_user()
|
||||
tweet.UserID = user.ID
|
||||
|
||||
// Save the user
|
||||
err := profile.SaveUser(user)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to save the user, so no point in continuing the test: %s", err.Error())
|
||||
}
|
||||
|
||||
// Save the tweet
|
||||
err = profile.SaveTweet(tweet)
|
||||
err := profile.SaveTweet(tweet)
|
||||
if err != nil {
|
||||
t.Errorf("Failed to save the tweet: %s", err.Error())
|
||||
}
|
||||
|
@ -10,7 +10,7 @@ import (
|
||||
)
|
||||
|
||||
/**
|
||||
* Load a test profile, or create it if it doesn't exist
|
||||
* Load a test profile, or create it if it doesn't exist.
|
||||
*/
|
||||
func create_or_load_profile(profile_path string) persistence.Profile {
|
||||
var profile persistence.Profile
|
||||
@ -18,6 +18,14 @@ func create_or_load_profile(profile_path string) persistence.Profile {
|
||||
|
||||
if !file_exists(profile_path) {
|
||||
profile, err = persistence.NewProfile(profile_path)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
err = profile.SaveUser(create_stable_user())
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
err = profile.SaveTweet(create_stable_tweet())
|
||||
} else {
|
||||
profile, err = persistence.LoadProfile(profile_path)
|
||||
}
|
||||
@ -27,6 +35,53 @@ func create_or_load_profile(profile_path string) persistence.Profile {
|
||||
return profile
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a stable user with a fixed ID and handle
|
||||
*/
|
||||
func create_stable_user() scraper.User {
|
||||
return scraper.User{
|
||||
ID: scraper.UserID("-1"),
|
||||
DisplayName: "stable display name",
|
||||
Handle: scraper.UserHandle("handle stable"),
|
||||
Bio: "stable bio",
|
||||
FollowersCount: 10,
|
||||
FollowingCount: 2000,
|
||||
Location: "stable location",
|
||||
Website:"stable website",
|
||||
JoinDate: time.Unix(10000000, 0),
|
||||
IsVerified: true,
|
||||
IsPrivate: false,
|
||||
ProfileImageUrl: "stable profile image url",
|
||||
BannerImageUrl: "stable banner image url",
|
||||
PinnedTweetID: scraper.TweetID("345"),
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a stable tweet with a fixed ID and content
|
||||
*/
|
||||
func create_stable_tweet() scraper.Tweet {
|
||||
tweet_id := scraper.TweetID("-1")
|
||||
return scraper.Tweet{
|
||||
ID: tweet_id,
|
||||
UserID: "-1",
|
||||
Text: "stable text",
|
||||
PostedAt: time.Unix(10000000, 0),
|
||||
NumLikes: 10,
|
||||
NumRetweets: 10,
|
||||
NumReplies: 10,
|
||||
NumQuoteTweets: 10,
|
||||
Videos: []scraper.Video{},
|
||||
Urls: []string{},
|
||||
Images: []scraper.Image{},
|
||||
Mentions: []scraper.UserHandle{},
|
||||
Hashtags: []string{},
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Create a new user with a random ID and handle
|
||||
*/
|
||||
@ -69,11 +124,11 @@ func create_dummy_tweet() scraper.Tweet {
|
||||
NumRetweets: 2,
|
||||
NumReplies: 3,
|
||||
NumQuoteTweets: 4,
|
||||
Videos: []scraper.Video{scraper.Video{TweetID: tweet_id, Filename: "video", IsDownloaded: false}},
|
||||
Videos: []scraper.Video{scraper.Video{TweetID: tweet_id, Filename: "video" + string(tweet_id), IsDownloaded: false}},
|
||||
Urls: []string{"url1", "url2"},
|
||||
Images: []scraper.Image{
|
||||
scraper.Image{TweetID: tweet_id, Filename: "image1", IsDownloaded: false},
|
||||
scraper.Image{TweetID: tweet_id, Filename: "image2", IsDownloaded: false},
|
||||
scraper.Image{TweetID: tweet_id, Filename: "image1" + string(tweet_id), IsDownloaded: false},
|
||||
scraper.Image{TweetID: tweet_id, Filename: "image2" + string(tweet_id), IsDownloaded: false},
|
||||
},
|
||||
Mentions: []scraper.UserHandle{"mention1", "mention2"},
|
||||
Hashtags: []string{"hash1", "hash2"},
|
||||
|
Loading…
x
Reference in New Issue
Block a user