/**
     * @author etao
     * @description check last time selected
     * @param timePeriod
     * @param dateFormat
     * @CreateDate 21 Dec 2016 13:50:39
     * @modifyUser
     * @modifyDate
     * @comments
     */
    public void checkLastTimeSelected(String timePeriod, String dateFormat){
        List<WebElement> lastTimeSelectedList = page.getLastTimeSelectedList();
        List<String> dateStr = new ArrayList<String>();
        for (WebElement e : lastTimeSelectedList) {
            String tempStr = e.getText().trim();
            tempStr = tempStr.split(" ")[0];            
            dateStr.add(tempStr.trim());
        }
        isAllTimeCorrect(dateFormat, timePeriod, dateStr);
    }

    public void isAllTimeCorrect(String dateFormat, String timePeriod, List<String> date) {
        for (String selectedDay : date) {
            if(timePeriod.equals("Last Day")){
                checkReportDateInTimeRange(Calendar.DAY_OF_MONTH, -1, dateFormat, selectedDay);                
            }else if (timePeriod.equals("Last Week")) {
                checkReportDateInTimeRange(Calendar.DATE, -7, dateFormat, selectedDay);
            }else if (timePeriod.equals("Last Month")) {
                checkReportDateInTimeRange(Calendar.MONTH, -1, dateFormat, selectedDay);
            }else if (timePeriod.equals("Last 2 Months")) {
                checkReportDateInTimeRange(Calendar.MONTH, -2, dateFormat, selectedDay);
            }else if (timePeriod.equals("Last 3 Months")) {
                checkReportDateInTimeRange(Calendar.MONTH, -3, dateFormat, selectedDay);
            }else if (timePeriod.equals("Last 6 Months")) {
                checkReportDateInTimeRange(Calendar.MONTH, -6, dateFormat, selectedDay);
            }else if (timePeriod.equals("Last 9 Months")) {
                checkReportDateInTimeRange(Calendar.MONTH, -9, dateFormat, selectedDay);
            }else if (timePeriod.equals("Last Year")) {
                checkReportDateInTimeRange(Calendar.YEAR, -1, dateFormat, selectedDay);
            }
        }
    }

    public void checkReportDateInTimeRange(int calendar, int diff, String dateFormat ,String selectedDay) {
        java.text.SimpleDateFormat format = new java.text.SimpleDateFormat(dateFormat, Locale.US);
        List<String> dateStr = new ArrayList<String>();
        Calendar c = Calendar.getInstance();
        dateStr.add(format.format(c.getTime()));//add date of today into string
        dateStr.add(selectedDay);//add date of selected date into string
        c.add(calendar, diff);
        c.add(Calendar.DATE, -1);
        dateStr.add(format.format(c.getTime()));//add date of last time range
        Assert.assertTrue(checkDatePeriod(dateStr, dateFormat),"The last time selected date is not in the time range");        
    }

    public boolean checkDatePeriod(List<String> date, String dateFormat) {
        boolean flg = true;    
        DateFormat df = new SimpleDateFormat(dateFormat, Locale.US);
        try {
            for (int i = 1; i < date.size(); i++) {
                Date d1 = df.parse(date.get(i - 1));
                Date d2 = df.parse(date.get(i));
                flg = flg && (d1.getTime() >= d2.getTime());
                if (flg == false) {
                    System.out.println("******* In the third return");
                    System.out.println("=== date -1: " + date.get(i - 1).toString());
                    System.out.println("=== date: " + date.get(i).toString());
                    if (i + 1 < date.size()) {
                        System.out.println("=== date +1: " + date.get(i + 1).toString());
                    }
                    break;
                }
            }
            return flg;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return false;
    }

check time period的更多相关文章

  1. 珍藏的数据库SQL基础练习题答案

    自己珍藏的数据库SQL基础练习题答案 一,基本表的定义与删除. 题1: 用SQL语句创建如下三张表:学生(Student),课程表(Course),和学生选课表(SC),这三张表的结构如表1-1到表1 ...

  2. Verilog中的specify block和timing check

    在ASIC设计中,有两种HDL construct来描述delay信息: 1)Distributed delays:通过specify event经过gates和nets的time,来描述delay; ...

  3. HDU 5908 Abelian Period 暴力

    Abelian Period 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5908 Description Let S be a number st ...

  4. Java 8 – Period and Duration examples

    Few examples to show you how to use Java 8 Duration, Period and ChronoUnit objects to find out the d ...

  5. -Dmaven.multiModuleProjectDirectory system property is not set. Check $M2_HO 解决办法

    最近在使用maven,项目测试的时候出现了这么一个错.-Dmaven.multiModuleProjectDirectory system property is not set. Check $M2 ...

  6. SQL Server 合并复制遇到identity range check报错的解决

        最近帮一个客户搭建跨洋的合并复制,由于数据库非常大,跨洋网络条件不稳定,因此只能通过备份初始化,在初始化完成后向海外订阅端插入数据时发现报出如下错误: Msg 548, Level 16, S ...

  7. SharePoint 2103 Check user permission on list

    一.需求: check user 对SharePoint list 的permission 代码如下: private static string GetListPermission(SPList l ...

  8. 用SVN check out项目后第三方库丢失

    曾经用Cornerstone check out 一份项目下来,但其中第三方.a库始终丢失,项目报错,研究后找到了以下解决方法: 首先,Xcode默认忽略.a 文件.所以无法提交到svn服务器,但是很 ...

  9. SQL Check

    一款实时性能监测工具 SQL Check? 一款实时监测SQL数据库性能.实时排查的问题的免费工具. 可以实时监测20个左右的SQL关键性能指标,每个指标都已图形化动态直播形式展现. 适合DBA.数据 ...

随机推荐

  1. java面向对象---对象初始化

    在本地变量中,如果定义了一个变量后没有赋值就使用,那么eclipse就会报错:但是在成员变量中,java是会强制给一个没有初始化的变量一个默认的初始值0, 如果是一个boolean类型的变量,那么默认 ...

  2. 测试ajax发送数据时在控制台看不到请求信息

    都是因为我把alert(xmlhttp);alert(url);打印测试数据放到了xmlhttp.open("GET",url,true);之前,导致后面的发送请求不执行了!

  3. nodeJS 简单的模块。

    nodeJS是的模块流程: 第一步:创建模块,如:student.js 第二步:导出模块,如:exports.add = function(){} 第三步:加载模块,如:var student = r ...

  4. QQ远程桌面的使用

    腾讯QQ怎样使用远程桌面: ---------------------- ----------------------

  5. [Android]快捷键

    小技巧,快捷键 快捷键创建资源: Windows下是 alt+enter; Mac下是Option+enter 创建构造函数,Get/Set:Command+N,Windows环境中Alt + Ins ...

  6. centos 单独安装apachebench

    这两天在测试php性能优化方法. 为了做压力测试可观察效果,就选择了ApacheBench来作为压力测试工具.其实就是大家常说的ab. 但是这个工具是安装apache web server的时候自带的 ...

  7. 用Canvas实现动画效果

    1.清除Canvas的内容 clearRect(x,y,width,height)函数用于清除图像中指定矩形区域的内容 <!doctype html> <html> <h ...

  8. 1.1、MyEclipse自定义注释

    一.修改进入路径: Window->Preference->Java->Code Style->Code Template->Comments 二:编辑自定义注释 文件  ...

  9. SQL 从指定表筛选指定行信息 获取表行数

    1.获取指定表的行数 --获取表中数据行数 --select max([列名]) from 表名 2.筛选指定表的指定行数据(数据表分页获取) http://www.cnblogs.com/morni ...

  10. HDOJ 1358

    Period Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...