blob: 1c0ab533aa85827c83403915c72c91354ae69e92 [file] [log] [blame]
// Copyright 2021 The Chromium OS Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
package wallpaper
import (
"context"
"path/filepath"
"time"
"chromiumos/tast/ctxutil"
"chromiumos/tast/fsutil"
"chromiumos/tast/local/chrome"
"chromiumos/tast/local/chrome/ash"
"chromiumos/tast/local/chrome/uiauto"
"chromiumos/tast/local/chrome/uiauto/faillog"
"chromiumos/tast/local/chrome/uiauto/nodewith"
"chromiumos/tast/local/chrome/uiauto/role"
"chromiumos/tast/local/media/imgcmp"
"chromiumos/tast/local/screenshot"
"chromiumos/tast/local/wallpaper"
"chromiumos/tast/local/wallpaper/constants"
"chromiumos/tast/testing"
)
func init() {
testing.AddTest(&testing.Test{
Func: SetLocalWallpaper,
LacrosStatus: testing.LacrosVariantUnneeded,
Desc: "Test setting local wallpapers in the new wallpaper app",
Contacts: []string{
"jasontt@google.com",
"chromeos-sw-engprod@google.com",
"assistive-eng@google.com",
},
Attr: []string{"group:mainline", "informational"},
Data: []string{constants.LocalWallpaperFilename},
SoftwareDeps: []string{"chrome"},
Timeout: 5 * time.Minute,
Fixture: "chromeLoggedIn",
})
}
func SetLocalWallpaper(ctx context.Context, s *testing.State) {
cr := s.FixtValue().(*chrome.Chrome)
cleanupCtx := ctx
ctx, cancel := ctxutil.Shorten(ctx, 10*time.Second)
defer cancel()
tconn, err := cr.TestAPIConn(ctx)
if err != nil {
s.Fatal("Failed to create Test API connection: ", err)
}
// Force Chrome to be in clamshell mode to make sure wallpaper view is clearly
// visible for us to compare it with the given rgba color.
cleanup, err := ash.EnsureTabletModeEnabled(ctx, tconn, false)
if err != nil {
s.Fatal("Failed to ensure DUT is not in tablet mode: ", err)
}
defer cleanup(cleanupCtx)
defer faillog.DumpUITreeOnError(cleanupCtx, s.OutDir(), s.HasError, tconn)
filePath, err := wallpaper.LocalImageDownloadPath(ctx, cr.NormalizedUser(), constants.LocalWallpaperFilename)
if err != nil {
s.Fatalf("Failed to get path for file %v, %v: ", constants.LocalWallpaperFilename, err)
}
if err := fsutil.CopyFile(s.DataPath(constants.LocalWallpaperFilename), filePath); err != nil {
s.Fatalf("Could not copy %s to %s: %v", constants.LocalWallpaperFilename, filePath, err)
}
// The test has a dependency of network speed, so we give uiauto.Context ample
// time to wait for nodes to load.
ui := uiauto.New(tconn).WithTimeout(30 * time.Second)
if err := uiauto.Combine("Set a new custom wallpaper and minimize wallpaper picker",
wallpaper.OpenWallpaperPicker(ui),
wallpaper.SelectCollection(ui, constants.LocalWallpaperCollection),
wallpaper.SelectImage(ui, constants.LocalWallpaperFilename),
wallpaper.MinimizeWallpaperPicker(ui),
)(ctx); err != nil {
s.Fatal("Failed to set new wallpaper: ", err)
}
// percentage takes into account the center cropped image is similar to the filled
// one.
const expectedPercent = 70
if err := wallpaper.ValidateBackground(cr, constants.LocalWallpaperColor, expectedPercent)(ctx); err != nil {
s.Error("Failed to validate wallpaper background: ", err)
}
// Take a screenshot of the current wallpaper.
firstScreenshot, err := screenshot.GrabScreenshot(ctx, cr)
if err != nil {
s.Fatal("Failed to grab screenshot: ", err)
}
if err := uiauto.Combine("Set a new custom wallpaper, choose new layout and minimize wallpaper picker",
wallpaper.OpenWallpaperPicker(ui),
wallpaper.SelectCollection(ui, constants.LocalWallpaperCollection),
ui.LeftClick(nodewith.Name("Center").Role(role.ToggleButton)),
wallpaper.MinimizeWallpaperPicker(ui),
)(ctx); err != nil {
s.Fatal("Failed to set new wallpaper: ", err)
}
// Take a screenshot of the same wallpaper with new layout.
secondScreenshot, err := screenshot.GrabScreenshot(ctx, cr)
if err != nil {
s.Fatal("Failed to grab screenshot: ", err)
}
// Verify that the wallpaper has indeed changed.
if err = wallpaper.ValidateDiff(firstScreenshot, secondScreenshot, expectedPercent); err != nil {
firstScreenshotPath := filepath.Join(s.OutDir(), "screenshot_1.png")
secondScreenshotPath := filepath.Join(s.OutDir(), "screenshot_2.png")
if err := imgcmp.DumpImageToPNG(ctx, &firstScreenshot, firstScreenshotPath); err != nil {
s.Errorf("Failed to dump image to %s: %v", firstScreenshotPath, err)
}
if err := imgcmp.DumpImageToPNG(ctx, &secondScreenshot, secondScreenshotPath); err != nil {
s.Errorf("Failed to dump image to %s: %v", secondScreenshotPath, err)
}
s.Fatal("Failed to validate wallpaper difference: ", err)
}
}