/**
     * @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. centos7下使用yum安装mysql

    CentOS7的yum源中默认好像是没有mysql的.为了解决这个问题,我们要先下载mysql的repo源. 1. 下载mysql的repo源 wget http://repo.mysql.com/m ...

  2. AnjularJS系列6 —— 过滤器

    第六篇,过滤器 AngularJS 过滤器可用于转换数据: 过滤器 描述 currency 格式化数字为货币格式. filter 从数组项中选择一个子集. lowercase 格式化字符串为小写. o ...

  3. php 远程本地化无后缀图片

    $body = '<p style="margin: 0px 0px 1.1em; padding: 0px; color: rgb(51, 51, 51); font-family: ...

  4. javascript 数字格式化

    对数字进行格式化输出,是非常有意义的一件事情,例如许多时候,我们希望一个数字能够输出为指定格式的字符串,拿25.9878来说,我们可能会希望它能保留两位小数来说出,即结果为25.99,或者对于0.34 ...

  5. JVM:查看java内存情况命令

    jmap (linux下特有,也是很常用的一个命令) 观察运行中的jvm物理内存的占用情况. 参数如下: -heap :打印jvm heap的情况 -histo: 打印jvm heap的直方图.其输出 ...

  6. ss命令和Recv-Q和Send-Q状态

    ss 用来显示处于活动状态的套接字信息.ss命令可以用来获取socket统计信息,它可以显示和netstat类似的内容.但ss的优势在于它能够显示更多更详细的有关TCP和连接状态的信息,而且比nets ...

  7. volatile关键字 学习记录1

    虽然已经工作了半年了...虽然一直是在做web开发....但是平时一直很少使用多线程..... 然后最近一直在看相关知识..所以就有了这篇文章 用例子来说明问题吧 public class Volat ...

  8. mysql获取一个表中的下一个自增(id)值的方法

    SELECT Auto_increment FROM information_schema.`TABLES` WHERE Table_Schema='数据库名' AND table_name = '表 ...

  9. 关于在vs2010中编译Qt项目时出现“无法解析的外部命令”的错误

    用Cmake讲Qt.VTK和ITK整合后,打开解决方案后添加新类时运行会出现“n个无法解析的外部命令”的错误. 原因是新建的类未能生成moc文件,解决办法是: 1.右键 要生成moc文件的.h文件,打 ...

  10. Go 项目的目录结构 及 安装技巧

    项目目录结构如何组织,一般语言都是没有规定.但 Go 语言这方面做了规定,这样可以保持一致性 1.一般的,一个 Go 项目在 GOPATH 下,会有如下三个目录: |--bin |--pkg |--s ...