2 * Copyright (C) 2010 Mathieu Baudier <mbaudier@argeo.org>
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 package org
.argeo
.slc
.gpx
.hibernate
;
20 import java
.io
.FileInputStream
;
22 import org
.apache
.commons
.io
.IOUtils
;
23 import org
.argeo
.slc
.gpx
.TrackDao
;
24 import org
.argeo
.slc
.hibernate
.unit
.HibernateTestCase
;
25 import org
.hibernatespatial
.HBSpatialExtension
;
26 import org
.hibernatespatial
.cfg
.HSConfiguration
;
28 public class HibernateTrackDaoTestCase
extends HibernateTestCase
{
30 HSConfiguration config
= new HSConfiguration();
31 config
.setDefaultDialect("org.hibernatespatial.postgis.PostgisDialect");
33 HBSpatialExtension
.setConfiguration(config
);
36 public void testImport() throws Exception
{
37 String sensor
= "mbaudier";
38 File dir
= new File("/home/mbaudier/ArgeoOffice/perso/gps/trips/2010");
40 TrackDao trackDao
= getBean(TrackDao
.class);
41 long begin
= System
.currentTimeMillis();
42 for (File file
: dir
.listFiles()) {
43 if (!file
.getName().endsWith(".gpx"))
45 FileInputStream in
= null;
47 in
= new FileInputStream(file
);
48 trackDao
.importTrackPoints(sensor
, in
);
49 } catch (Exception e
) {
50 log
.warn("Could not import " + file
+ ": " + e
.getMessage());
53 IOUtils
.closeQuietly(in
);
56 double duration
= System
.currentTimeMillis() - begin
;
57 if (log
.isDebugEnabled())
58 log
.debug("Imported files from " + dir
+ " in "
59 + (duration
/ 1000 / 60) + " min");