274 lines
7.8 KiB
Go
274 lines
7.8 KiB
Go
package persistence_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"fmt"
|
|
"math/rand"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
"github.com/go-test/deep"
|
|
|
|
"offline_twitter/scraper"
|
|
)
|
|
|
|
/**
|
|
* Create a user, save it, reload it, and make sure it comes back the same
|
|
*/
|
|
func TestSaveAndLoadUser(t *testing.T) {
|
|
require := require.New(t)
|
|
profile_path := "test_profiles/TestUserQueries"
|
|
profile := create_or_load_profile(profile_path)
|
|
|
|
fake_user := create_dummy_user()
|
|
|
|
// Save the user, then reload it and ensure it's the same
|
|
err := profile.SaveUser(&fake_user)
|
|
require.NoError(err)
|
|
|
|
new_fake_user, err := profile.GetUserByID(fake_user.ID)
|
|
require.NoError(err)
|
|
|
|
if diff := deep.Equal(new_fake_user, fake_user); diff != nil {
|
|
t.Error(diff)
|
|
}
|
|
|
|
// Same thing, but get by handle
|
|
new_fake_user2, err := profile.GetUserByHandle(fake_user.Handle)
|
|
require.NoError(err)
|
|
|
|
if diff := deep.Equal(new_fake_user2, fake_user); diff != nil {
|
|
t.Error(diff)
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
*/
|
|
func TestModifyUser(t *testing.T) {
|
|
assert := assert.New(t)
|
|
require := require.New(t)
|
|
|
|
profile_path := "test_profiles/TestUserQueries"
|
|
profile := create_or_load_profile(profile_path)
|
|
|
|
fake_user := create_dummy_user()
|
|
fake_user.DisplayName = "Display Name 1"
|
|
fake_user.Location = "location1"
|
|
fake_user.IsPrivate = false
|
|
fake_user.IsVerified = false
|
|
fake_user.IsBanned = false
|
|
fake_user.FollowersCount = 1000
|
|
fake_user.JoinDate = scraper.TimestampFromUnix(1000)
|
|
fake_user.ProfileImageUrl = "asdf"
|
|
fake_user.IsContentDownloaded = true
|
|
|
|
// Save the user so it can be modified
|
|
err := profile.SaveUser(&fake_user)
|
|
require.NoError(err)
|
|
|
|
fake_user.DisplayName = "Display Name 2"
|
|
fake_user.Location = "location2"
|
|
fake_user.IsPrivate = true
|
|
fake_user.IsVerified = true
|
|
fake_user.IsBanned = true
|
|
fake_user.FollowersCount = 2000
|
|
fake_user.JoinDate = scraper.TimestampFromUnix(2000)
|
|
fake_user.ProfileImageUrl = "asdf2"
|
|
fake_user.IsContentDownloaded = false // test No Worsening
|
|
|
|
// Save the modified user
|
|
err = profile.SaveUser(&fake_user)
|
|
require.NoError(err)
|
|
|
|
// Reload the modified user
|
|
new_fake_user, err := profile.GetUserByID(fake_user.ID)
|
|
require.NoError(err)
|
|
|
|
assert.Equal("Display Name 2", new_fake_user.DisplayName)
|
|
assert.Equal("location2", new_fake_user.Location)
|
|
assert.True(new_fake_user.IsPrivate)
|
|
assert.True(new_fake_user.IsVerified)
|
|
assert.True(new_fake_user.IsBanned)
|
|
assert.Equal(2000, new_fake_user.FollowersCount)
|
|
assert.Equal(int64(1000), new_fake_user.JoinDate.Unix())
|
|
assert.Equal("asdf2", new_fake_user.ProfileImageUrl)
|
|
assert.True(new_fake_user.IsContentDownloaded)
|
|
}
|
|
|
|
func TestHandleIsCaseInsensitive(t *testing.T) {
|
|
profile_path := "test_profiles/TestUserQueries"
|
|
profile := create_or_load_profile(profile_path)
|
|
|
|
user := create_stable_user()
|
|
|
|
new_user, err := profile.GetUserByHandle("hANdle StaBlE")
|
|
require.NoError(t, err, "Couldn't find the user")
|
|
|
|
if diff := deep.Equal(user, new_user); diff != nil {
|
|
t.Error(diff)
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Should correctly report whether the user exists in the database
|
|
*/
|
|
func TestUserExists(t *testing.T) {
|
|
require := require.New(t)
|
|
profile_path := "test_profiles/TestUserQueries"
|
|
profile := create_or_load_profile(profile_path)
|
|
|
|
user := create_dummy_user()
|
|
|
|
exists := profile.UserExists(user.Handle)
|
|
require.False(exists)
|
|
|
|
err := profile.SaveUser(&user)
|
|
require.NoError(err)
|
|
|
|
exists = profile.UserExists(user.Handle)
|
|
require.True(exists)
|
|
}
|
|
|
|
/**
|
|
* Test scenarios relating to user content downloading
|
|
*/
|
|
func TestCheckUserContentDownloadNeeded(t *testing.T) {
|
|
assert := assert.New(t)
|
|
profile_path := "test_profiles/TestUserQueries"
|
|
profile := create_or_load_profile(profile_path)
|
|
|
|
user := create_dummy_user()
|
|
|
|
// If user is not in database, should be "yes" automatically
|
|
assert.True(profile.CheckUserContentDownloadNeeded(user))
|
|
|
|
// Save the user, but `is_content_downloaded` is still "false"
|
|
user.BannerImageUrl = "banner url1"
|
|
user.ProfileImageUrl = "profile url1"
|
|
user.IsContentDownloaded = false
|
|
err := profile.SaveUser(&user)
|
|
require.NoError(t, err)
|
|
|
|
// If is_content_downloaded is false, then it needs download
|
|
assert.True(profile.CheckUserContentDownloadNeeded(user))
|
|
|
|
// Mark `is_content_downloaded` as "true" again
|
|
user.IsContentDownloaded = true
|
|
err = profile.SaveUser(&user)
|
|
require.NoError(t, err)
|
|
|
|
// If everything is up to date, no download should be required
|
|
assert.False(profile.CheckUserContentDownloadNeeded(user))
|
|
|
|
// Change an URL, but don't save it-- needs to be different from what's in the DB
|
|
user.BannerImageUrl = "banner url2"
|
|
|
|
// Download needed for new banner image
|
|
assert.True(profile.CheckUserContentDownloadNeeded(user))
|
|
}
|
|
|
|
/**
|
|
* Make sure following works
|
|
*
|
|
* - users are unfollowed by default
|
|
* - following a user makes it save as is_followed
|
|
* - using regular save method doesn't un-follow
|
|
* - unfollowing a user makes it save as no longer is_followed
|
|
*/
|
|
func TestFollowUnfollowUser(t *testing.T) {
|
|
assert := assert.New(t)
|
|
|
|
profile_path := "test_profiles/TestUserQueries"
|
|
profile := create_or_load_profile(profile_path)
|
|
|
|
user := create_dummy_user()
|
|
assert.False(user.IsFollowed)
|
|
err := profile.SaveUser(&user)
|
|
assert.NoError(err)
|
|
|
|
profile.SetUserFollowed(&user, true)
|
|
assert.True(user.IsFollowed)
|
|
|
|
// Ensure the change was persisted
|
|
user_reloaded, err := profile.GetUserByHandle(user.Handle)
|
|
require.NoError(t, err)
|
|
assert.Equal(user.ID, user_reloaded.ID) // Verify it's the same user
|
|
assert.True(user_reloaded.IsFollowed)
|
|
|
|
err = profile.SaveUser(&user) // should NOT un-set is_followed
|
|
assert.NoError(err)
|
|
user_reloaded, err = profile.GetUserByHandle(user.Handle)
|
|
require.NoError(t, err)
|
|
assert.Equal(user.ID, user_reloaded.ID) // Verify it's the same user
|
|
assert.True(user_reloaded.IsFollowed)
|
|
|
|
profile.SetUserFollowed(&user, false)
|
|
assert.False(user.IsFollowed)
|
|
|
|
// Ensure the change was persisted
|
|
user_reloaded, err = profile.GetUserByHandle(user.Handle)
|
|
require.NoError(t, err)
|
|
assert.Equal(user.ID, user_reloaded.ID) // Verify it's the same user
|
|
assert.False(user_reloaded.IsFollowed)
|
|
}
|
|
|
|
/**
|
|
* Should create a new Unknown User from the given handle.
|
|
* The Unknown User should work consistently with other Users.
|
|
*/
|
|
func TestCreateUnknownUserWithHandle(t *testing.T) {
|
|
assert := assert.New(t)
|
|
|
|
profile_path := "test_profiles/TestUserQueries"
|
|
profile := create_or_load_profile(profile_path)
|
|
|
|
next_id := profile.NextFakeUserID()
|
|
|
|
handle := scraper.UserHandle(fmt.Sprintf("UnknownUser%d", rand.Int31()))
|
|
user := scraper.GetUnknownUserWithHandle(handle)
|
|
assert.Equal(scraper.UserID(0), user.ID)
|
|
assert.True(user.IsIdFake)
|
|
|
|
err := profile.SaveUser(&user)
|
|
assert.NoError(err)
|
|
assert.Equal(scraper.UserID(next_id + 1), user.ID)
|
|
|
|
// Ensure the change was persisted
|
|
user_reloaded, err := profile.GetUserByHandle(user.Handle)
|
|
require.NoError(t, err)
|
|
assert.Equal(handle, user_reloaded.Handle) // Verify it's the same user
|
|
assert.Equal(scraper.UserID(next_id + 1), user_reloaded.ID)
|
|
|
|
// Why not tack this test on here: make sure NextFakeUserID works as expected
|
|
assert.Equal(next_id + 2, profile.NextFakeUserID())
|
|
}
|
|
|
|
/**
|
|
* Should update the unknown User's UserID with the correct ID if it already exists
|
|
*/
|
|
func TestCreateUnknownUserWithHandleThatAlreadyExists(t *testing.T) {
|
|
assert := assert.New(t)
|
|
|
|
profile_path := "test_profiles/TestUserQueries"
|
|
profile := create_or_load_profile(profile_path)
|
|
|
|
user := create_stable_user()
|
|
|
|
unknown_user := scraper.GetUnknownUserWithHandle(user.Handle)
|
|
assert.Equal(scraper.UserID(0), unknown_user.ID)
|
|
|
|
err := profile.SaveUser(&unknown_user)
|
|
assert.NoError(err)
|
|
assert.Equal(user.ID, unknown_user.ID)
|
|
|
|
// The real user should not have been overwritten at all
|
|
user_reloaded, err := profile.GetUserByID(user.ID)
|
|
assert.NoError(err)
|
|
assert.False(user_reloaded.IsIdFake) // This one particularly
|
|
assert.Equal(user.Handle, user_reloaded.Handle)
|
|
assert.Equal(user.Bio, user_reloaded.Bio)
|
|
assert.Equal(user.DisplayName, user_reloaded.DisplayName)
|
|
}
|